알고리즘

정수 제곱근 판별 [Math.sqrt(), Number.isInteger(), Math.pow(a,b)] (javascript)

려낭 2024. 10. 18. 00:03

문제 설명

임의의 양의 정수 n에 대해, n이 어떤 양의 정수 x의 제곱인지 아닌지 판단하려 합니다.

n이 양의 정수 x의 제곱이라면 x+1의 제곱을 리턴하고, n이 양의 정수 x의 제곱이 아니라면 -1을 리턴하는 함수를 완성하세요.

 

n은 1이상, 50000000000000 이하인 양의 정수입니다.

 

 

function solution(n) {
    let sqrt = Math.sqrt(n);
    if(Number.isInteger(sqrt)) {
        return Math.pow(sqrt + 1, 2);
    } else {
        return -1;
    }
}

 

 

let sqrt = Math.sqrt(n);

 

Math.sqrt(n) 함수로 n의 제곱근을 구한다.

 

if (Number.isInteger(sqrt)) {
return Math.pow(sqrt + 1, 2);
}

 

n이 정수의 제곱인지 확인한 후 , 그 정수보다 1이 큰 수의 제곱을 반환한다.

 

Number.isInteger()

()안의 수가 정수인지 확인해준다 

 

ex) Number.isInteger(4)는 true를 반환,

Number.isInteger(4.5)는 false를 반환한다.

 

Math.pow(a,b)

a를 b만큼 곱한 수를 계산해준다.

ex) a = 2 이고, b = 6 이면

2^6 = 64가 된다.

 

그러므로 Math.pow(sqrt + 1, 2)

sqrt한 값에 1을 더한 후 제곱을 한 값이 결과가 된다.