c语言判断一个数是否为素数的函数(c语言判断一个数是否为素数)
关于c语言判断一个数是否为素数的函数,c语言判断一个数是否为素数这个很多人还不知道,今天小六来为大家解答以上的问题,现在让我们一起来看看吧!
1、判断一个整数m是否是素数,只需把m被 2 ~ m-1 之间的每一个整数去除,如果都不能被整除,那么m就是一个素数。
2、思路1)的代码:#include 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是素数。
3、\", num);}else{printf(\"%d不是素数。
4、\", num);}return 0;}判断方法还可以简化。
5、m不必被 2 ~ m-1 之间的每一个整数去除,只需被 2 ~ 之间的每一个整数去除就可以了。
6、如果m不能被 2 ~ 间任一整数整除,m必定是素数。
7、例如判别17是是否为素数,只需使17被2~4之间的每一个整数去除,由于都不能整除,可以判定17是素数。
8、思路2)的代码:#include #include void main(){int m; // 输入的整数 int i; // 循环次数int k; // m 的平方根 printf(\"输入一个整数:\");scanf(\"%d\",&m);// 求平方根,注意sqrt()的参数为 double 类型,这里要强制转换m的类型 k=(int)sqrt( (double)m );for(i=2;ik if(i>k)printf(\"%d是素数。
9、\",m);elseprintf(\"%d不是素数。
10、\",m);return 0;}。
本文到此分享完毕,希望对大家有所帮助。