[Java] 정수 제곱근 판별 (programmers)

Haeun Noh·2022년 9월 1일
0

programmers

목록 보기
7/64
post-thumbnail

0902


문제 설명

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


제한 사항

n1이상, 50000000000000 이하인 양의 정수입니다.


입출력 예

nreturn
121144
3-1

입출력 예 설명

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

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


소스 코드

class Solution {
    public long solution(long n) {
        long answer = 0;
      
        for ( long x = 1L; x <= Math.sqrt(n); x++ ) {   //n의 제곱근까지 반복
            //x제곱이 n이면 (x+1)*(x+1)을 answer에 저장
            answer = ( x*x == n ? (x+1)*(x+1) : -1);
        }
        
        return answer;
    }
}

소스 풀이

public long solution(long n) {

외부에서 양의 정수를 뜻하는 n 변수를 가져온다.


	long answer = 0;

리턴할 값인 answerlong타입으로 초기화를 한다.


	for ( long x = 1L; x <= Math.sqrt(n); x++ ) {   //n의 제곱근까지 반복
        //x제곱이 n이면 (x+1)*(x+1)을 answer에 저장
        answer = ( x*x == n ? (x+1)*(x+1) : -1);
    }

양의 정수를 뜻하는 nlong타입이기 때문에 비교하는 x변수도 1L로 초기화한다.

xn의 제곱근과 같거나 작을 동안 for문을 반복한다.
Math.sqrt()()안의 변수의 제곱근을 구할 수 있는 메서드이다. 때문에 Math.sqrt(n)n의 제곱근을 의미한다.
x의 값을 n의 제곱근까지 설정한 이유는 x*x == n이기 때문에 xn의 제곱근이므로 그렇게 설정하였다.

삼항 연산자를 이용하여 answer에 리턴할 값을 저장한다.
만약 x*x == n조건이 이라면 (x+1)*(x+1) 값을 저장하고, 거짓이라면 -1을 저장한다.


return answer;

조건에 따른 값이 들어있는 answerreturn한다.



profile
기록의 힘을 믿는 개발자, 노하은입니다!

0개의 댓글