https://school.programmers.co.kr/learn/courses/30/lessons/12934
임의의 양의 정수 n에 대해, n이 어떤 양의 정수 x의 제곱인지 아닌지 판단하려 합니다.
n이 양의 정수 x의 제곱이라면 x+1의 제곱을 리턴하고, n이 양의 정수 x의 제곱이 아니라면 -1을 리턴하는 함수를 완성하세요.
n은 1이상, 50000000000000 이하인 양의 정수입니다.
n | return |
---|---|
121 | 144 |
3 | -1 |
입출력 예#1
입출력 예#2
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
long long solution(long long n) {
if (sqrt(n) == (int)sqrt(n)) { // 제곱근 n이 양의 정수일 때
return pow(sqrt(n) + 1, 2); // (제곱근 n) + 1의 제곱 반환
}
else return -1; // 제곱근 n이 양의 정수가 아닐 때 -1 반환
}
if 문으로 제곱근 n이 양수인지 아닌지 판단한다.
양의 정수라면 제곱근 n + 1의 제곱을 반환하고, 양의 정수가 아니라면 -1을 반환한다.
math 함수는 배웠긴 한데 써본적이 거의 없어서 잊고 있었다.. 어떻게 쓰는지 검색하고 문제를 푸니까 할 만 했다!