728x90
* 에라토스테네스란 ? 소수를 찾아내는 방법
- 2부터 소수를 구하고자 하는 구간의 모든 수를 나열한다. 그림에서 회색 사각형으로 두른 수들이 여기에 해당한다.
- 2는 소수이므로 오른쪽에 2를 쓴다. (빨간색)
- 자기 자신을 제외한 2의 배수를 모두 지운다.
- 남아있는 수 가운데 3은 소수이므로 오른쪽에 3을 쓴다. (초록색)
- 자기 자신을 제외한 3의 배수를 모두 지운다.
- 남아있는 수 가운데 5는 소수이므로 오른쪽에 5를 쓴다. (파란색)
- 자기 자신을 제외한 5의 배수를 모두 지운다.
- 남아있는 수 가운데 7은 소수이므로 오른쪽에 7을 쓴다. (노란색)
- 자기 자신을 제외한 7의 배수를 모두 지운다.
- 위의 과정을 반복하면 구하는 구간의 모든 소수가 남는다.
이므로 11보다 작은 수의 배수들만 지워도 충분하다. 즉, 120보다 작거나 같은 수 가운데 2, 3, 5, 7의 배수를 지우고 남는 수는 모두 소수이다.
#include <stdio.h>
#define max 1000
int main() {
int N, K, a[max];
scanf_s("%d %d", &N, &K);
for (int i = 2; i <= N; i++) { // 배열 초기화
a[i] = i;
}
for (int i = 2; i <= N; i++) {
if (a[i] == 0) continue; // 이미 지운 경우
for (int j = i + i; j <= N; j += i) { // i의 배수를 모두 지움
a[j] = 0;
}
}
for (int i = 2; i <= N; i++) { // N보다 작은 소수
if (a[i] != 0) printf("%d", a[i]);
}
}
참고
728x90
'언어 > C, C++' 카테고리의 다른 글
[C] 별 찍기 (0) | 2022.09.28 |
---|---|
[C] 입력받은 정수의 약수 구하기 (0) | 2022.09.28 |
[C] do-while 문 (0) | 2022.09.28 |
[C] 16진수로 출력하기 (0) | 2022.09.28 |
[C] scanf로 입력받기 (0) | 2022.05.24 |