输入格式:
输入在一行中给出 M 和 N,其间以空格分隔。
输出格式:
输入样例:
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
代码:
初出茅庐,请多指教!
注意:PAT提交时编译器一定要选c++(g++)
#include<stdio.h>
bool isPrime(int n){
for(int i=2;i*i<=n;i++){
if(n%i==0) return false;
}
return true;
}
int main(){
int M,N;
if(scanf("%d%d",&M,&N)){
if(M>N||M<=0||N<=0||M>10000||N>10000){
printf("M or N error!\n");
return 0;
}
int i=2;
int count=0;
int primegroup[10005];
while(count!=N){
if(isPrime(i)==true){
primegroup[count]=i;
count++;
}
i++;
}
int num=0;
for(i=M-1;i<=N-2;i++){
printf("%d",primegroup[i]);
num++;
if(num%10==0) printf("\n");
else printf(" ");
}
printf("%d",primegroup[N-1]);
}
return 0;
}