养成好习惯,点个赞 再走;有问题,欢迎私信、评论,我看到都会回复的
- 素数是指在大于1的自然数中,除了1和它本身以外不再有其他因数的自然数。
- 因数是指整数m除以整数n(n≠0) 的商正好是整数而没有余数,我们就说n是m的因数。
一: 判断一个整数m是否是素数,只需把 m 被 2 ~ m-1 之间的每一个整数去除,如果都不能被整除,那么 m 就是一个素数
二: 上面的判断方法还可以简化:m 不必被 2 ~ m-1 之间的每一个整数去除,只需被 2 ~ √m 之间的每一个整数去除就可以了。如果 m 不能被 2 ~ √m 间任一整数整除,m 必定是素数。
如果 m 能被 2 ~ m-1 之间任一整数整除,其二个因子必定有一个小于或等于 √m,另一个大于或等于 √m
例如判别 27 是是否为素数,只需使 25 被 2~5 之间的每一个整数去除,由于都不能整除,可以判定 27 是素数。
for(int n = 2; n <= sqrt(m); n++)
if(m % n == 0){
leap = 0; //若条件判断成功,则m不为素数
break;
}
打印100到200之间的素数及输出素数的个数
#include<stdio.h>
#include<math.h>
int main()
{
int i, j,
t = 0, //记录素数的个数
leap = 1;//leap用来判断是否为素数
for(i = 101; i <= 200; i++){
for(j = 2; j <= sqrt(i); j++) //判断i是否为素数
if(i % j == 0){
leap = 0;
break;
}
if(leap == 1){
printf("%-5d", i); //左对齐,为了好看
t++;
}
leap = 1;
if(t % 10 == 0) printf("\n"); //一行就放10个,为了好看
}
return 0;
}
输出:
101 103 107 109 113 127 131 137 139 149
151 157 163 167 173 179 181 191 193 197
199
编写判别素数的函数,主函数输出200以内的素数
#include<stdio.h>
#include<math.h>
int main(){
int Mer(int n);
printf("200以内的素数有:\n");
for(int n = 2; n <= 200; n++){
if(Mer(n)) printf("%5d", Mer(n));
}
return 0;
}
int Mer(int n){
int i;
for(i = 2; i < sqrt(n); i++){
if(n % i == 0) break;
}
if(i > sqrt(n)) return n;
else return 0;//非素数,返回0
}
输出:
200以内的素数有:
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 101 103 107 109 113 127 131 137 139 149 151 157 163 167 173 179 181 191 193 197 199
C语言入门题目文章导航:
- 本篇文章
- 水仙花数(C)
- 斐波那契数列(C)
- 完数(C)
- 阶乘(C)
- 直角杨辉三角形(C)
- 大写字母、小写字母、ASCII码(C)
- 输入一个字符,找出他的前驱字符和后继字符(C)
- 最大数、最小数(C)
- 百钱买百鸡(C语言,枚举法)
- 辗转相除法求最大公约数,利用最大公约数求最小公倍数(C)
- 输入一个年份和一个月份,输出该年此月天数;知道日期,计算该日是本年的第几天(C)
- 输入一个不多于4位的正整数,求它的位数,并按逆序输出各位数字(C)
- 利用二维数组求方阵的主次对角线之和(C)
- 在一个二维数组中找出最小数及其所在的行和列(C)
- 找出一个二维数组中的鞍点(C)
- 删除指定字符串的指定字符(C)
- 字符串(C)
- 条件判断语句1(C)
- 条件判断语句2(C)
- 圆、三角形、正方形、长方体、计算1到100的和、和差积商、平均值
- 输入三个整数,要求程序把数据按从小到大的顺序放入x y z中,然后输出(C)
- 18个数围成一圈,求相邻三数之和最大数(C)
- 梯形法求定积分(C)
- 学生与课程的综合问题(C)