解题思路以及注意事项:
打表法,大家要学会用这种奇异的方法来解这一题,不然怎么凸显我们的逼格呢?
对1到1000进行遍历,让所有的非素数为1,素数为0,然后我们需要看一个数是
不是素数的时候就简单了,只需要看看数组里那个位置存的是0还是1就可以了。
2是素数,则4不是素数,6不是,后面就是偶数了(判断所以能被2整除的数),
i+1为3,j=6不是,6+3,不是(所以3 的倍数的全不是素数),就是这样类似的方
法就可以让数组质数的位置里面存1。
实例代码:
#include"stdio.h" //打表法 #include"math.h" void prime(); int a[1000]={0}; //定义全局的数组a[1000],也可以定义到main()里面,不过那样需要传参 int main() //不要定义到prime里面,prime()调用完毕所有的数据将不可知 { int i,number,check=0; prime(); scanf("%d",&number); if(a[number]==0) { printf("prime\n"); } else { printf("not prime\n"); } return 0; } void prime() { int i=2,j; for(i=2;i<1000;i++)/ for(j=i+i;j<1000;j+=i) { a[j]=1; //让这些数(不是素数)全部为1,其余为0; } }
大家还有什么不懂的就请到下面评论区留言,小方会为大家解答
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:1327 |
简单的a+b (C语言代码)浏览:564 |
2004年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:539 |
【计算两点间的距离】 (C语言代码)浏览:1522 |
DNA (C语言代码)浏览:564 |
1009题解浏览:802 |
简单的a+b (C语言代码)浏览:457 |
循环入门练习6 (C语言代码)浏览:1058 |
1035 题解浏览:875 |
C二级辅导-分段函数 (C语言代码)浏览:659 |
q330226 2018-01-03 19:33:53 |
提示编译错误