题目链接:https://www.patest.cn/contests/pat-b-practise/1013
1013. 数素数 (20)
时间限制
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
本题很基础,但是我还是提交了好几次。问题如下:
1、换行问题。逢十换行,不要多也不要少。要在每次输出之前检查是否换行,免得多了换行符。
2、数组要足够大,这里第10000个素数,开辟1000000大小的数组。不然一直有一个测试点过不了。
代码如下:
#include<iostream>
using namespace std;
const int maxn=1000000;//弄大一点
int num[maxn],prime[maxn];
void Prime(){//素数表
int cnt=0;
for(int i=2;i<maxn;i++){
if(num[i]==1) continue;
prime[cnt++]=i;
for(int j=2*i;j<maxn;j+=i) num[j]=1; //可以j从i²开始
}
}
int main(){
Prime();
int m,n;
cin>>m>>n;
int first=1,cnt=0;
for(int i=m-1;i<n;i++){
if(cnt!=0&&cnt%10==0){cout<<endl;first=1; } //输出之前检查是否换行
if(first){cout<<prime[i];cnt++;first=0; }
else {cout<<' '<<prime[i];cnt++;}
}
return 0;
}