문제 설명
임의의 양의 정수 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을 더한 후 제곱을 한 값이 결과가 된다.
'알고리즘' 카테고리의 다른 글
reduce 함수 (0) | 2025.01.06 |
---|---|
서울에서 김서방 찾기 [indexOf()] 자바스크립트 (0) | 2024.10.21 |
정수 내림차순으로 배치하기 [sort, split, join] (javascript) (0) | 2024.10.17 |