定义一个判断素数的函数FindPrimer直接找符合要求的素数。从键盘输入m,用m调用FindPrimer,函数中先将m增1以满足获得“大于m的素数”的要求,从m+1开始穷举判断,将第一个为素数的数返回,此返回值便是题解。代码如下:
#include "stdio.h"
int FindPrimer(int m){//判断素数
int i;
while(m++){
if(m>2 && !(m&1) || m<2)//小于2和大于2的偶数不是素数
continue;
for(i=3;i*i<=m;i+=2)//有大于1小于等于自身平方根的因子的数也非素数
if(!(m%i))
break;
if(i*i<=m)
continue;
break;
}
return m;//剩下的肯定是素数了
}
int main(int argc,char *argv[]){
int m;
printf("Input m(int m>0)...\nm=");
if(scanf("%d",&m)!=1 || m<1){//输入m需大于0
printf("Input error, exit...\n");
return 0;
}
printf("The smallest prime number of greater than %d is ",m);
printf("%d\n",FindPrimer(m));//调用自定义函数寻找大于m的第一个素数
return 0;
}
运行样例如下图:
![](https://video.ask-data.xyz/img.php?b=https://iknow-pic.cdn.bcebos.com/d4628535e5dde7118a721371adefce1b9c166190?x-bce-process=image%2Fresize%2Cm_lfit%2Cw_600%2Ch_800%2Climit_1%2Fquality%2Cq_85%2Fformat%2Cf_auto)