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

문제

정수 제곱근 판별  

 

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

 

제한 사항

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

 

 

 

코드

#include <math.h>

using namespace std;

long long solution(long long n) 
{
    int resInt;
    double resDouble;
    
    resInt = resDouble = sqrt(n);
    
    if(resInt == resDouble)
        return pow(resInt+1, 2);
    else
        return -1;
    
}

 

나의 생각

굳이 int와 double 변수 둘 다 사용할 필요가 없었다.

 

기저에 깔린 개념은 동일한데 다음 코드가 더 깔끔한 것 같다.

#include <math.h>

using namespace std;

long long solution(long long n) 
{
    int a = sqrt(n);
    
    if(pow(a,2) == n)
        return pow(a+1, 2);
    else
        return -1;
}