[프로그래머스] - 정수 제곱근 판별

jsbak·2021년 5월 25일
0

알고리즘

목록 보기
1/19

링크 : https://programmers.co.kr/learn/courses/30/lessons/12934

문제설명

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

제한 사항

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

문제 풀이

n의 제곱근이 양수인지 판별하는 문제이다.
따라서 Math.sqrt() 메서드의 리턴값이 양의 정수 인지 판별하면 된다.

소스코드

import java.lang.*;

class Solution {
    public long solution(long n) {
    
        // n의 제곱근 이 x와 같은지 확인
        double nnn = Math.sqrt((double) n );
        
        // n의 제곱근이 양의 정수라면 정수형에서 실수형으로
        // 변환한뒤 다시 빼면 값이 0이어야한다.
        if(nnn - (double)((long)nnn) != 0) return -1;
        else {
            long nn = (long)Math.sqrt((double)n);
            return ++nn*nn;
        }
    }
}
profile
끄적끄적 쓰는곳

0개의 댓글