[백준] BOJ_1978 JAVA

BOJ_1978 소수 찾기

문제

주어진 수 N개 중에서 소수가 몇 개인지 찾아서 출력하는 프로그램을 작성하시오.


입력

첫 줄에 수의 개수 N이 주어진다. N은 100이하이다. 다음으로 N개의 수가 주어지는데 수는 1,000 이하의 자연수이다.


출력

주어진 수들 중 소수의 개수를 출력한다.


예제 입&출력


소스코드

import java.io.*;
import java.util.*;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st;

        int n = Integer.parseInt(br.readLine());
        st = new StringTokenizer(br.readLine());

        int cnt = 0;

        while ((n--) > 0) {
            int num = Integer.parseInt(st.nextToken());
            if (isSosu(num)) {
                cnt++;
            }
        }
        System.out.println(cnt);
    }

    private static boolean isSosu(int num) {
        if (num < 2) return false;

        for (int i = 2; i <= Math.sqrt(num); i++) {
            if(num % i == 0) return false;
        }
        return true;
    }


}

Comment

  • 가장 기본적으로 소수를 찾는 방법이다.

좋은 웹페이지 즐겨찾기