原题链接:[编程入门]自定义函数处理素数
解题思路以及注意事项:
打表法,大家要学会用这种奇异的方法来解这一题,不然怎么凸显我们的逼格呢?
对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语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复