令 Pi表示第 i 个素数。现任给两个正整数 M≤N≤10的4次方,请输出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<cstdio>
//养成习惯:有数组的题先const
const int maxn=1000001;//这个地方,maxn搞大一点,我第一次因为maxn太小了有一个测试点没通过
int ans[maxn];//ans就是要求的素数表
int pnum=0;
bool p[maxn]={0};//p是一个bool型数组,里面除了false就是true
//不要用bool p[maxn]={1};这个思路,因为bool型函数的确除了false就是true,但是并不是除了0就是1
void judge(int n){//整个judge函数是用来生成素数表的
for(int i=2;i<maxn;++i){
if(p[i]==false){
ans[pnum++]=i;
if(pnum>=n) break;//因为题意只需要判断m~n,所以我们只需要n个素数
for(int j=i+i;j<maxn;j+=i){
p[j]=true;
}
}
}
}
int main(){
int m,n;
scanf("%d %d",&m,&n);
judge(n);//要调用n,就要提到一下,不然judge中报错:n was not declared
int cnt=0;
for(int i=m;i<n+1;++i){
printf("%d",ans[i-1]);//数组中下标从0开始,所以需要减一
++cnt;//万能的计数器!
if(i<n&&cnt%10!=0) printf(" ");
else printf("\n");
}
return 0;
}
博客给出一个程序需求,给定两个正整数 M 和 N(M≤N≤10 的 4 次方),需输出第 M 个到第 N 个素数。同时说明了输入格式为一行给出 M 和 N 且以空格分隔,输出格式为每 10 个素数占一行,行末无多余空格,并给出了输入输出样例。
&spm=1001.2101.3001.5002&articleId=95381151&d=1&t=3&u=0343b841e517488f99e52efb4d342089)
489

被折叠的 条评论
为什么被折叠?



