素数又称质数。所谓素数是指除了 1 和它自己之外,不能被任何整数整除的数,例如17就是素数,由于它不能被 2~16 的任一整数整除。
思路1):所以判断一个整数m是不是素数,只需把 m 被 2 ~ m-1 之间的每个整数去除,若是都不能被整除,那么 m 就是一个素数。
思路2):另外判断方法还能够简化。m 没必要被 2 ~ m-1 之间的每个整数去除,只需被 2 ~ 之间的每个整数去除就能够了。若是 m 不能被 2 ~ 间任一整数整除,m 一定是素数。例如判别 17 是是否为素数,只需使 17 被 2~4 之间的每个整数去除,因为都不能整除,能够断定 17 是素数。
缘由:由于若是 m 能被 2 ~ m-1 之间任一整数整除,其二个因子一定有一个小于或等于 ,另外一个大于或等于 。例如 16 能被 二、四、8 整除,16=28,2 小于 4,8 大于 4,16=44,4=√16,所以只需断定在 2~4 之间有无因子便可。
思路一代码以下:
ios
#include <stdio.h> int main(){ int a=0; // 素数的个数 int num=0; // 输入的整数 printf("输入一个整数:"); scanf("%d",&num); for(int i=2;i<num;i++){ if(num%i==0){ a++; // 素数个数加1 } } if(a==0){ printf("%d是素数。\n", num); }else{ printf("%d不是素数。\n", num); } return 0; }
思路二代码以下:
spa
#include <stdio.h> #include <math.h> void main(){ int m; // 输入的整数 int i; // 循环次数 int k; // m 的平方根 printf("输入一个整数:"); scanf("%d",&m); // 求平方根,注意sqrt()的参数为 double 类型,这里要强制转换m的类型 k=(int)sqrt( (double)m ); for(i=2;i<=k;i++) if(m%i==0) break; // 若是完成全部循环,那么m为素数 // 注意最后一次循环,会执行i++,此时 i=k+1,因此有i>k if(i>k) printf("%d是素数。\n",m); else printf("%d不是素数。\n",m); return 0; }
来一道简单的竞赛题让你们练练手:3d
时间限制: 1Sec 内存限制: 128MB 提交: 3567 解决: 2346
题目描述 用简单素数筛选法求N之内的素数。 输入 N
输出 2~N的素数
样例输入 100
样例输出code
2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97
答案以下
blog
#include <stdio.h> int main() { int N,i,j; scanf("%d",&N); for(i=2; i<=N; i++) //遍历2~N之间的全部数 { for(j=2; j<=i; j++) //j至关于0~i之间的全部数,i%若是除0~i之间的全部数都都不能除尽,那么i是素数。 { //i%j==0说明i能整除j 当i和j相等时,那么i%j必须为0 if(i%j==0&&i!=j) //若是j不是在最后一个i=j的状况下i%j==0,说明在j在取0~i的某个值时,i能将其整除,所以i确定不是素数。 break; if(i%j==0&&i==j) //说明i%(0~i之间)都不能除尽,只有最后i==j的状况下才能除尽,此时已经把全部数都判断完了,i是素数 printf("%d\n",i); } } return 0; }
运行结果图
内存
上题中求2~M之间全部的素数,那么M~N之间全部的素数应该怎么求?
//扩展:求M和N间的素数 C++语言 #include <iostream> using namespace std; int main() { int M,N; cin>>M>>N; for(int i=M; i<=N; i++) //遍历M~N之间全部数 { for(int j=2; j<=i; j++) //j取0~i之间全部数 若是i%(0~i全部数)!==0 则i是素数 { if(i%j==0&&i!=j) break; if(i%j==0&&i==j) cout<<i<<endl; } } }
运行结果图
ci