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

까말·2020년 9월 27일
0

문제 설명

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

제한 조건

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

입출력 예

n   return
121   144
3    -1

풀이

#include <string>
#include <vector>
#include <math.h>

using namespace std;

long long solution(long long n) {
    long long answer = 0;
    
    long long i = sqrt(n);
    
        if(i * i == n)
        {
            answer = pow(i+1, 2);
        }
        else
        {
            answer = -1;
        }
    
    return answer;
}

sqrt(a) = 어떠한 값에 루트를 씌워서 계산한 값을 반환해준다.

pow(a, b) = a값을 b만큼 제곱해준다

두가지 수학 함수를 사용할땐 #include <math.h> 추가 해줘야함

i값을 int로 할경우는 몇몇 가지 테스트할때 에러남.. 정수형이라

profile
취업준비중........!!

0개의 댓글