비버놀로지

[Programmers 프로그래머스] 12921 소수 찾기 본문

ALGORITM/JAVA

[Programmers 프로그래머스] 12921 소수 찾기

KUNDUZ 2021. 1. 7. 11:03
728x90

programmers.co.kr/learn/courses/30/lessons/12921

 

코딩테스트 연습 - 소수 찾기

1부터 입력받은 숫자 n 사이에 있는 소수의 개수를 반환하는 함수, solution을 만들어 보세요. 소수는 1과 자기 자신으로만 나누어지는 수를 의미합니다. (1은 소수가 아닙니다.) 제한 조건 n은 2이상

programmers.co.kr

입력값의 소수를 찾는 문제이다.

큰 숫자의 소수를 찾을때에는 root를 이용해야 시간초과가 나지 않는다.

그래서 root값을 이용을 해서 for문을 돌면서 소수인 값을 false로 만들어 주고, false의 수를 세어주어 값을 출력한다.

import java.util.Arrays;

class Solution {
    public int solution(int n) {
		int answer=0;
		boolean []sosu=new boolean[n+1];
		Arrays.fill(sosu, true);
		int root=(int)Math.sqrt(n);
		for (int i = 2; i <= root; i++) {
			if(sosu[i]==true) {
				for (int j = i; i*j <= n; j++) {
					sosu[i*j]=false;
				}
			}
			
		}
		for (int i = 2; i <=n; i++) {
			if(sosu[i]==true) {
				answer++;
			}
		}
        return answer;
    }
}
728x90
Comments