코테 - 정수 제곱근

Mixer·2023년 11월 22일
0
post-custom-banner

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

[제한 사항]
n은 1이상, 50000000000000 이하인 양의 정수입니다.

입출력 예
n -> return
121 -> 144
3 -> -1

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

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

class Solution {
    public long solution(long n) {
        long answer = 0;
        Double x = Math.sqrt(n); // a
        if( x == x.intValue()) { // b
            answer = (long) Math.pow(x + 1, 2);
        } else { // c
            answer = -1;
        }
        return answer;
    }
}

풀이
a) Math.sqrt 메서드를 이용해 n 값의 제곱근을 x 변수에 담아준다.
Math.sqrt의 반환 타입은 Double 형이라 변수의 타입을 double 로 선언해준다

b) 실수형인 x의 값을 intValue() 메서드를 사용하여 x 값을 정수 값으로 반환한다.
-> n = 121 일때 x는 실수값인 11.0 으로 출력되어 intValue() 메서드를 사용해 정수형인 11로 출력한다.
Math.pow 함수를 이용해 x + 1의 제곱의 값을 answer 변수에 담고, Math.pow의 반환이 Double이므로 (long)형으로 형변환 해준다

c) 양의 정수가 아니라면 -1 반환한다.

profile
Minthug'life
post-custom-banner

0개의 댓글