본문 바로가기
알고리즘/백준

[백준/자바] 1978 소수 찾기

by Renechoi 2022. 12. 1.

[백준/자바] 1978 소수 찾기

 

📌 문제 

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

 

 

⚔ 입력

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

 

 

📣 출력

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

 

 

 

 


 

 

 

💎 문제분석

 

1인 소수가 아니기 때문에 따로 처리해준다. 

 

 

💡 코드 구현

 

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main {

	private static long answerCount;

	public static void main(String[] args) throws IOException {

		BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer stringTokenizer = new StringTokenizer(bufferedReader.readLine());

		int numbers = Integer.parseInt(stringTokenizer.nextToken());

		stringTokenizer = new StringTokenizer(bufferedReader.readLine());

		while (numbers-- > 0) {
			int number = Integer.parseInt(stringTokenizer.nextToken());
			if (isPrime(number)) {
				answerCount++;
			}
		}
		System.out.println(answerCount);
	}

	private static boolean isPrime(int number) {
		if (number == 1){
			return false;
		}

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

}

 

 

 

 

 

 

 

 

 


반응형