본문 바로가기

TIL(today i learned)/프로그래머스-코딩테스트

[연습문제][Lv.1] 정수 제곱근 판별

문제

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

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

 

나의 답

Math.sqrt() 함수를 이용해 n의 루트 값이 양수이며 정수인 경우에 문제에서 요구한 값을 answer로 리턴하도록 짜주었다.

두개의 조건 중 하나라도 일치하지 않을 경우, -1을 리턴하도록 하였다.

function solution(n) {
    var answer = 0;
    let x = Math.sqrt(n);
    if ( x > 0 && x % 1 === 0){
        answer = (x+1)*(x+1)
    } else answer = -1;
    return answer;
}

 

코드 더 간결하게 짜기

ternary operator를 통해 더욱 간결하게 짜 주었다. 

function solution(n) {
    let x = Math.sqrt(n);
    return x % 1 === 0 ? (x+1)*(x+1) : -1
}