Coding Test/Baekjoon

[백준/Python] 1978번: 소수 찾기 풀이

여름0401 2021. 5. 12. 22:23

백준의 다른 소수 찾기 문제 풀이

2021.05.13 - [Coding Test/Baekjoon] - [백준/Python] 1929번: 소수 구하기 풀이

2021.05.12 - [Coding Test/Baekjoon] - [백준/Python] 2581번: 소수


출처: https://www.acmicpc.net/problem/1978

문제

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

 

입력

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

 

출력

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


풀이 전략

에라토스테네스의 체를 구현하지 않아도 통과할 수 있다.(참고: [내가 보려고 적는 파이썬] 소수 판별(에라토스테네스의 체) (velog.io))

 

1) 1이 있다면 제거한다.

2) 2~N까지 자신을 제외한 자신의 배수를 제거한다. (단, N은 배열 내 최대값)

- 최적화: 2~√N까지만 구하면 효율성을 높일 수 있다.(참고: [C] 소수 판별하기 / 에라토스테네스의 체 / 소인수 분해 (tistory.com))

3) 남은 배열의 크기를 출력한다.


코드