Posis

[프로그래머스] 제곱수 판별하기 본문

알고리즘/프로그래머스

[프로그래머스] 제곱수 판별하기

CooNiHong 2022. 11. 30. 17:16

문제 링크

https://school.programmers.co.kr/learn/courses/30/lessons/120909

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

문제 설명

어떤 자연수를 제곱했을 때 나오는 정수를 제곱수라고 합니다. 정수 n이 매개변수로 주어질 때, n이 제곱수라면 1을 아니라면 2를 return하도록 solution 함수를 완성해주세요.

제한사항

  • 1 ≤ n ≤ 1,000,000

입출력 예

n result
144 1
976 2

입출력 예 설명

입출력 예 #1

  • 144는 12의 제곱이므로 제곱수입니다. 따라서 1을 return합니다.

입출력 예 #2

  • 976은 제곱수가 아닙니다. 따라서 2를 return합니다.

나의 풀이

Java

class Solution {
    public int solution(int n) {
        double maxNum = Math.sqrt(1000000);
        int answer = 0;
        for(int i = 1; i <= maxNum; i++) {
            double num = Math.pow(i,2);
            if(num == n) {
                answer = 1;
                break;
            }
            answer = 2;
        }
        return answer;
    }
}

JavaScript

function solution(n) {
    return (n%Math.sqrt(n) == 0) ? 1 : 2;
}
728x90