문제 설명
어떤 자연수를 제곱했을 때 나오는 정수를 제곱수라고 합니다. 정수 n이 매개변수로 주어질 때, n이 제곱수라면 1을 아니라면 2를 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ n ≤ 1,000,000
입출력 예
n | result |
144 | 1 |
976 | 2 |
입출력 예 설명
입출력 예 #1
- 144는 12의 제곱이므로 제곱수입니다. 따라서 1을 return합니다.
입출력 예 #2
- 976은 제곱수가 아닙니다. 따라서 2를 return합니다.
function solution(n) {
return Math.sqrt(n) % 1 === 0 ? 1 : 2;
}
Math.sqrt()로 해당 숫자를 제곱근으로 만들고, 정수는 1로 나누었을 경우 나머지가 항상 0이 됨으로 이를 판별하는 것을 조건으로 함
Math.sqrt() : 숫자의 제곱근을 반환함. 숫자가 음수일 경우 NaN을 반환함.
Number.isInteger() : 주어진 값이 정수인지 판별함.
https://school.programmers.co.kr/learn/courses/30/lessons/120909
'study > Algorithm' 카테고리의 다른 글
[프로그래머스] 개미 군단 (0) | 2022.12.10 |
---|---|
[프로그래머스] 배열의 유사도 (0) | 2022.12.10 |
[프로그래머스] 문자 반복 출력하기 (0) | 2022.12.10 |
[프로그래머스] 최댓값 만들기 (1) (0) | 2022.12.10 |
[프로그래머스] 짝수는 싫어요 (0) | 2022.12.10 |