알고리즘 Algorithm/BOJ 백준 (초급~중급)
[BOJ 백준] 에라토스테네스의 체(2960) C++
섭코딩
2023. 1. 12. 02:07
링크 : https://www.acmicpc.net/problem/2960
문제 설명 :
더보기
에라토스테네스의 체는 N보다 작거나 같은 모든 소수를 찾는 유명한 알고리즘이다.
이 알고리즘은 다음과 같다.
- 2부터 N까지 모든 정수를 적는다.
- 아직 지우지 않은 수 중 가장 작은 수를 찾는다. 이것을 P라고 하고, 이 수는 소수이다.
- P를 지우고, 아직 지우지 않은 P의 배수를 크기 순서대로 지운다.
- 아직 모든 수를 지우지 않았다면, 다시 2번 단계로 간다.
N, K가 주어졌을 때, K번째 지우는 수를 구하는 프로그램을 작성하시오.
입력 :
더보기
첫째 줄에 N과 K가 주어진다. (1 ≤ K < N, max(1, K) < N ≤ 1000)
출력 :
더보기
첫째 줄에 K번째 지워진 수를 출력한다.
예제 입력 :
더보기
15 12
예제 출력 :
더보기
7
접근법 :
1) 어떻게 풀 것인가?
2) 시간복잡도
3) 공간복잡도
4) 풀면서 놓쳤던점
5) 이 문제를 통해 얻어갈 것
C++ 코드 :
// 에라토스테네스의 체 2960
#if 1
#pragma warning(disable:4996)
#include <cstdio>
#define MAX (1000+3)
using namespace std;
bool isNotPrimenumber[MAX]; // 기본값 false
int N, K;
int main() {
// 1. 입력받는다
//freopen("input.txt", "r", stdin);
scanf("%d %d", &N, &K);
// 2. 에라토스테네스의 체
int cnt = 0; // 지운 횟수 카운트
for (int i = 2; i <= N; i++) {
// 1) 이미 지워졌으면 pass
if (isNotPrimenumber[i] == true) {
continue;
}
// 2) 배수 제거
for (int j = i; j <= N; j += i) {
if (isNotPrimenumber[j] == false) {
isNotPrimenumber[j] = true;
cnt++;
// K번째 지우는 순간 출력
if (cnt == K) {
printf("%d", j);
return 0;
}
}
}
}
return 0;
}
#endif
반응형