프로그래머스 1단계 : 정수 제곱근 판별 (굴복해버렸다...)
임의의 양의 정수 n에 대해, n이 어떤 양의 정수 x의 제곱인지 아닌지 판단하려 합니다.
n이 양의 정수 x의 제곱이라면 x+1의 제곱을 리턴하고, n이 양의 정수 x의 제곱이 아니라면 -1을 리턴하는 함수를 완성하세요.
제한 사항
n은 1이상, 50000000000000 이하인 양의 정수입니다.
나의 문제 풀이
우선 간결하게 하기 위해 삼향 연산자를 사용했으며, 제곱근과 관련된 수학 객체 Math.sqrt(), Math.pow()를 사용했습니다.
function solution(n) {
var answer = 0;
var x = 0;
answer = Math.sqrt(n) % 1 === 0 ? Math.pow(Math.sqrt(n)+1,2) : -1
return answer
}
다른 사람 문제 풀이
for문 사용과 if문을 사용하여 n을 i로 나눴을 때 i와 같을 때 a가 문제 의도대로 +1 되도록 아니면 -1 되도록 만든 것 같습니다.
function solution(n) {
var answer = 0;
for(let i=0, a=0; i<=n; i++){
if(n/i===i){
a = i + 1
return a*a
} else {
answer = -1
}
}
return answer;
}
'PRO' 카테고리의 다른 글
프로그래머스 1단계 : 하샤드 수 (0) | 2022.11.04 |
---|---|
프로그래머스 1단계 : 문자열 내 p와 y의 개수 (0) | 2022.11.03 |
프로그래머스 1단계 : 자연수 뒤집어 배열로 만들기 (0) | 2022.10.31 |
프로그래머스 1단계 : 자릿수 더하기 (0) | 2022.10.31 |
프로그래머스 1단계 : 짝수와 홀수 (0) | 2022.10.31 |
댓글