문제
M이상 N이하의 소수를 모두 출력하는 프로그램을 작성하시오.
입력
첫째 줄에 자연수 M과 N이 빈 칸을 사이에 두고 주어진다. (1 ≤ M ≤ N ≤ 1,000,000) M이상 N이하의 소수가 하나 이상 있는 입력만 주어진다.
출력
한 줄에 하나씩, 증가하는 순서대로 소수를 출력한다.
예제 입력 1
3 16
예제 출력 1
3
5
7
11
13
풀이
에라토스테네스의 채를 이용하여 풀었다.
에라토스테네스의 채
- 2부터 소수를 구하고자 하는 구간의 모든 수를 나열한다. 그림에서 회색 사각형으로 두른 수들이 여기에 해당한다.
- 2는 소수이므로 오른쪽에 2를 쓴다. (빨간색)
- 자기 자신을 제외한 2의 배수를 모두 지운다.
- 남아있는 수 가운데 3은 소수이므로 오른쪽에 3을 쓴다. (초록색)
- 자기 자신을 제외한 3의 배수를 모두 지운다.
- 남아있는 수 가운데 5는 소수이므로 오른쪽에 5를 쓴다. (파란색)
- 자기 자신을 제외한 5의 배수를 모두 지운다.
- 남아있는 수 가운데 7은 소수이므로 오른쪽에 7을 쓴다. (노란색)
- 자기 자신을 제외한 7의 배수를 모두 지운다.
- 위의 과정을 반복하면 구하는 구간의 모든 소수가 남는다.
이므로 11보다 작은 수의 배수들만 지워도 충분하다. 즉, 120보다 작거나 같은 수 가운데 2, 3, 5, 7의 배수를 지우고 남는 수는 모두 소수이다.
m, n = map(int, input().split())
n += 1
num_list = [True for _ in range(n)]
for i in range(2, int(n**0.5) + 1):
if num_list[i] == True:
for j in range(2*i, n, i):
num_list[j] = False
for i in range(m, n):
if i >1 and num_list[i] == True:
print(i)
반응형
'Algorithm > Online judge' 카테고리의 다른 글
[백준] 1085번 > 직사각형에서 탈출 (0) | 2021.02.10 |
---|---|
[백준] 4948번 > 베르트랑 공준 (0) | 2021.02.10 |
[백준] 11653번 > 소인수분해 (0) | 2021.02.09 |
[백준] 4673번 > 셀프넘버 (0) | 2021.02.08 |
[백준] 2839번 > 설탕 배달 (0) | 2021.02.08 |