[프로그래머스] Lv.1 정수 제곱근 판별 JavaScript

Janet·2023년 2월 23일
0

Algorithm

목록 보기
26/314

문제 설명

임의의 양의 정수 n에 대해, n이 어떤 양의 정수 x의 제곱인지 아닌지 판단하려 합니다.n이 양의 정수 x의 제곱이라면 x+1의 제곱을 리턴하고, n이 양의 정수 x의 제곱이 아니라면 -1을 리턴하는 함수를 완성하세요.

제한 사항

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

입출력 예

nreturn
121144
3-1

입출력 예 설명

입출력 예#1121은 양의 정수 11의 제곱이므로, (11+1)를 제곱한 144를 리턴합니다.

입출력 예#23은 양의 정수의 제곱이 아니므로, -1을 리턴합니다.


문제풀이

💡 문제풀이 과정

  • 제곱근(Square root) 값을 계산 해주는 함수 Math.sqrt()와 거듭제곱 값을 계산 해주는 함수인 Math.pow()를 이용했다.
    // Math.sqrt(대상 숫자)
    console.log(Math.sqrt(9)); // 3
    
    // Math.pow(대상 숫자, 거듭제곱 횟수)
    console.log(Math.pow(9, 1); // 9
    console.log(Math.pow(9, 2); // 81
  • 조건문을 사용하여, n은 양의 정수이고 n의 제곱근 값을 1로 나눴을 때 나머지가 0이 아닌 경우 즉, 소숫점인 경우 -1을 리턴해준다.

✅ 답안 #1 (IF / ELSE)

function solution(n) {
  let answer = 0;
  let sqrt = Math.sqrt(n);
  if (sqrt % 1 !== 0) answer = -1;
  else answer = Math.pow(sqrt + 1, 2);
  return answer;
}

✅ 답안 #2 (삼항 연산자)

function solution(n) {
  let sqrt = Math.sqrt(n);
  return sqrt % 1 !== 0 ? -1 : Math.pow(sqrt + 1, 2);
}
profile
😸

0개의 댓글