用c语言求1000以内的素数(素数是只能被1和它本身整除的数)
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用c语言求1000以内的素数(素数是只能被1和它本身整除的数)相关的知识,希望对你有一定的参考价值。
参考技术A int i,j,k;for(i=2;i<=1000;i++)
k=0;
for(j=2;j<i;j++)
if(i%j==0)
k=1;
break;
if(k=0)
printf("%d",i);
主体这样,前缀什么的自己加上就好了。 参考技术B main()
int a=1,b;
printf("1 ");
while(a<=1000)
b=2;
do
if(a%b==0)
break;
b++;
while(b<a);
if(b==a)
printf("%d ",a);
a++;
一楼是错的算不出来因为他的K是== 1也是质素 数字要分开才行本回答被提问者采纳
素数筛选法
素数筛选法
素数(又称质数):指在大于一的自然数中,只能被1和它自身整除的自然数;
素数筛选法是指一种非常规的素数判定方法,比较高效率;
原理:任何数的整数倍必定不是素数,大于二的偶数必定不是素数。
我们以找出100以内的素数为例,利用原理,我们可以首先排除偶数是素数,然后进一步判断奇数
实现将偶数标记为0,素数标记为1;(也可以用一个bool数组将偶数标记为false,奇数标记为true)
下面是全部代码
#include <iostream> #include <cmath> #define MAX 100 using namespace std; int main() { //设置标记,将偶数标记为0 int prime[MAX+1]; for(int i=1;i<=MAX;i++) { if(i%2==0) { prime[i]=0; } else prime[i]=1; } for(int i=3;i<=sqrt(MAX);i++) { if(prime[i]==1) { for(int j=i+i;j<=MAX;j=j+i) { prime[j]=0; } } } cout<<"2"<<" "; for(int i=3;i<=MAX;i++) { if(prime[i]==1) cout<<i<<" "; } return 0; }
以上是关于用c语言求1000以内的素数(素数是只能被1和它本身整除的数)的主要内容,如果未能解决你的问题,请参考以下文章