题目连接:https://pintia.cn/problem-sets/994805260223102976/problems/994805309963354112
令 P i 表示第 i 个素数。现任给两个正整数 M≤N≤10 4 ,请输出 P M 到 P N 的所有素数。
输入格式:
输入在一行中给出 M 和 N,其间以空格分隔。
输出格式:
输出从 P M 到 P N 的所有素数,每 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
这里要注意几个问题:
1.第10000位素数是104729,所以开的数组要足够大
2.输出格式问题:注意N==M的情况
#include <iostream>
#define max 1000000
using namespace std;
int p[1001000] = {0}, cnt = 0, n[1001000] = {0};
int main(){
int M, N;
cin >> M >> N;
//打素数表
for(int i = 2; i > 0; i++){
if(cnt >= N) break;
if(!n[i]) p[cnt++] = i;
for(int j = 2*i; j < max; j += i)
n[j] = 1;
}
//输出
int count = 1;
for(int i = M-1; i < N-1; i++){
cout << p[i];
if(count % 10 && M!=N)
cout << " ";
else if(!(count%10))
cout << endl;
count++;
}
cout << p[N-1];
return 0;
}```