문제 링크입니다: https://www.acmicpc.net/problem/1929
에라토스테네스의 체를 복습할 수 있었던 간단한 문제였습니다.
#include <iostream>
#include <cstring>
using namespace std;
const int MAX = 1000000 + 1;
int minFactor[MAX];
void erathosthenes(void)
{
minFactor[0] = minFactor[1] = -1;
for (int i = 2; i < MAX; i++)
minFactor[i] = i;
for (int i = 2; i*i <= MAX; i++)
if (minFactor[i] == i)
for (int j = i * i; j < MAX; j += i)
if (minFactor[j] == j)
minFactor[j] = i;
}
int main(void)
{
ios_base::sync_with_stdio(0);
cin.tie(0);
int M, N;
cin >> M >> N;
erathosthenes();
for (int i = M; i <= N; i++)
if (minFactor[i] == i)
cout << i << "\n";
return 0;
}
개발환경:Visual Studio 2017
지적, 조언, 질문 환영입니다! 댓글 남겨주세요~
'알고리즘 > BOJ' 카테고리의 다른 글
백준 11723번 집합 (0) | 2018.11.05 |
---|---|
백준 16205번 변수명 (0) | 2018.11.05 |
백준 3184번 양 (0) | 2018.11.04 |
백준 2617번 구슬 찾기 (0) | 2018.11.04 |
백준 2851번 슈퍼 마리오 (0) | 2018.11.04 |