C语言:判断一个数是否为素数(3种方法,含注释)
时间:2024-03-26 13:46:00 来源:网络cs 作者:峨乐 栏目:卖家故事 阅读:
阅读本书更多章节>>>>
首先要先明白素数的定义:除了1和本身之外,没有其他的因数的数,即不能被其他数整除。
同时要注意,1不是素数。
以下为判断素数的3个代码:
1.要注意给m赋初值是不能为1,因为1是任何数的因数,可以被任何数整除。若初值为1,则第一步就结束循环,所有的数输出结果均为不是素数(1除外),无法起到判断作用。
#include<stdio.h>int main(){ int i, m; printf("请输入一个大于一的整数:"); scanf("%d", &i); for (m = 2; m <= i; m++) if (i % m == 0)//当2-m之间遇到因数时,结束循环 break; if (m == i)//如果遇到的因数就是它本身,是素数 printf("%d是素数", i); else printf("%d不是素数", i); return 0;}
2.此代码中,count的作用是计算这个数的因数个数,如果是2,即只有1和本身,是素数。
#include<stdio.h>int main(){ int i, m; int count = 0; printf("请输入一个大于1的整数:\n"); scanf("%d", &i); for (m = 1; m <= i; m++) { if (i % m == 0)//统计要判断的数的因数个数 count++; } if (count == 2)//如果只有2个因数 printf("%d是素数", i); else printf("%d不是素数", i); return 0; }
3.此代码中引用了求平方根sqrt函数,所以要引用math.h;对半取,可以节省空间。
#include<stdio.h>#include<math.h>//求平方根需要引用int main(){ int n, m, i;//定义需要用到的变量 printf("请输入一个大于1的正整数:"); scanf("%d", &n);//输入要判断的数 m = sqrt(n);//求输入数的平方根 for (i = 2; i <= m; i++)//取2-m之间的每一个整数 if (n % i == 0)//判断能否整除n break;//非素数,跳出循环 if (i > m) printf("%d是素数!\n", n);//循环正常结束,是素数 else printf("%d不是素数!\n", n);//循环中途退出,不是素数 return 0;}
阅读本书更多章节>>>>
本文链接:https://www.kjpai.cn/gushi/2024-03-26/148923.html,文章来源:网络cs,作者:峨乐,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
下一篇:返回列表