一个关于C语言的小程序 10

不太懂题目中所说的筛选的方法需要用数组么?有没有可以减少循环的方法呢?谢谢~关于素数的筛选... 不太懂题目中所说的筛选的方法需要用数组么?有没有可以减少循环的方法呢?谢谢~
关于素数的筛选
展开
 我来答
听不清啊
高粉答主

2016-11-28 · 说的都是干货,快来关注
知道顶级答主
回答量:7.8万
采纳率:89%
帮助的人:1.9亿
展开全部
#include<stdio.h>
#include<math.h>
#include<string.h>
char s[500001];
int main()
{int a,b,i,j;
memset(s,1,sizeof(s));
s[1]=0;
for(i=2;i<=sqrt(500001);i++)
if(s[i])
for(j=i+i;j<500001;j+=i)s[j]=0;
while(scanf("%d%d",&a,&b)!=EOF)
{for(i=a;i<=b;i++)
if(s[i])printf("%d\n",i);
printf("\n");
}
return 0;
}
匿名用户
2016-11-28
展开全部
已知的素数,其倍数不是素数,所以如此筛选。

~
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式