문제
임의의 양의 정수 n에 대해, n이 어떤 양의 정수 x의 제곱인지 아닌지 판단하려 합니다.
n이 양의 정수 x의 제곱이라면 x+1의 제곱을 리턴하고, n이 양의 정수 x의 제곱이 아니라면 -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;
}
'Algorithm > 프로그래머스 : Level 1' 카테고리의 다른 글
[프로그래머스 Level 1] 제일 작은 수 제거하기 (0) | 2021.11.18 |
---|---|
[프로그래머스 Level 1] 문자열 내 p와 y의 개수 (0) | 2021.11.17 |
[프로그래머스 Level 1] 문자열 내 마음대로 정렬하기 (0) | 2021.11.16 |
[프로그래머스 Level 1] 정수 내림차순으로 배치하기 (0) | 2021.11.16 |
[프로그래머스 Level 1] 자연수 뒤집어 배열로 만들기 (0) | 2021.11.15 |