原文链接: PAT B1013. 数素数 (20)
上一篇: 图的bf算法
1013. 数素数 (20)
https://www.patest.cn/contests/pat-b-practise/1013
时间限制
100 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
CHEN, Yue
令Pi表示第i个素数。现任给两个正整数M <= N <= 104,请输出PM到PN的所有素数。
输入格式:
输入在一行中给出M和N,其间以空格分隔。
输出格式:
输出从PM到PN的所有素数,每10个数字占1行,其间以空格分隔,但行末不得有多余空格。
输入样例:
5 27
输出样例:
11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 101 103
#include <iostream>
#include <cstdio>
using namespace std;
const int MAX = 1000001;
int prime[MAX], num = 0;
bool p[MAX]; //p[i] == false 表示i是素数
//筛法
void getPrime(int n) {
for (int i = 2; i < MAX; i++)
if (p[i] == false) {
prime[num++] = i;
if (num >= n) break;
for (int j = i + i; j < MAX; j += i)
p[j] = true;
}
}
int main(int argc, char *argv[]) {
int m, n, count = 0;
scanf("%d%d", &m, &n);
getPrime(n);
for (int i = m; i <= n; i++) {
printf("%d", prime[i - 1]);
count++;
if (count % 10 != 0 && i < n) printf(" ");
else printf("\n");
}
return 0;
}