令 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
思路
根据题意,可以提前算出前10000个素数分别是多少,存在数组里,然后根据n和m的值直接从数组输出结果即可,注意输出格式,用变量c来数数,数到10就\n。
AC代码
#include<stdio.h>
#include<math.h>
int judge(int n){//素数判断
if(n<2)return 0;
for(int i=2;i<=sqrt(n);i++){
if(n%i==0)return 0;
}
return 1;
}
int main(){
int p[10001],m,n,temp=0,c=0;
scanf("%d %d",&m,&n);
for(int i=1;i<=10000;i++){//计算范围内所有素数
while(1){
if(judge(++temp)){
p[i]=temp;
break;
}
}
}
for(int i=m;i<=n;i++){//输出
printf("%d",p[i]);
if(++c!=10&&i!=n){
printf(" ");
}
else{
printf("\n");
c=0;
}
}
return 0;
}