[프로그래머스] 제곱수 판별하기
카테고리 : 컴퓨터 공학
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 제곱수 판별하기 · js 제곱수 판별하기
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 제곱수 판별하기 · js 제곱수 판별하기
문제 설명
어떤 자연수를 제곱했을 때 나오는 정수를 제곱수라고 합니다. 정수 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) {
var sqrt = Math.sqrt(n);
return sqrt % 1 === 0 ? 1 : 2;
}
나의 두번째 풀이(Code Refactoring)
function solution(n) {
return n ** 0.5 % 1 === 0 ? 1 : 2;
}
// n의 루트를 씌우려면 n의 거듭제곱 .5를 해야줘야 제곱근을 구할 수 있다
// 예를들어 25 = 5**2의 2는 5의 제곱근 (5/2)이다
// 제곱근이 정수 또는 소수 인데 %1 결과값이 0이면 어떤 정수의 제곱근이므로 1 나누어 떨어지지 않는다면 제곱근이 소수이다
참고 할 만한 다른 사람의 코드
function solution(n) {
return Number.isInteger(Math.sqrt(n)) ? 1 : 2;
}
// 가장 깔끔한 코드