| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 458 人关注过本帖
标题:这个筛选法求素数看不懂啊,你们指点一下吧
只看楼主 加入收藏
CRUISEQUAN
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2012-12-7
结帖率:0
收藏
已结贴  问题点数:10 回复次数:11 
这个筛选法求素数看不懂啊,你们指点一下吧
#include<stdio.h>
int main()
{
int i,j,a[50];
for(i=0;i<50;i++)
a[i]=i+1;
for(i=0;i<50;i++)
{
j=i-1;
while(j>1)
{
if(a[i]%j==0)
a[i]=0;
j=j-1;
}
}
for(j=1;j<50;j++)
{
if(a[j]!=0)
{
printf("%2d ",a[j]);
}
}
}
这是求50内的素数
2012-12-08 10:45
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:3 
肯定是网上抄的 哈

DO IT YOURSELF !
2012-12-08 10:46
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
帮你整理了一下代码 看起来不那么乱了啊
程序代码:
#include<stdio.h>
int main()
{
    int i,j,a[50];
    for(i=0;i<50;i++) a[i]=i+1;//给数组赋初值1--50
    for(i=0;i<50;i++)
    {
        j=i-1;
        while(j>1) {if(a[i]%j==0) a[i]=0;j=j-1;}  //核心部分 看是否是合数
    }
    //本重循环打印输出素数(非0数 0表示被筛掉的)
    for(j=1;j<50;j++) if(a[j]!=0) printf("%2d ",a[j]); 
    return 0;
}



[ 本帖最后由 wp231957 于 2012-12-8 11:20 编辑 ]

DO IT YOURSELF !
2012-12-08 10:54
CRUISEQUAN
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2012-12-7
收藏
得分:0 
回复 3楼 wp231957
核心部分真的看不懂啊,你说详细点吧,真心不懂
2012-12-08 10:58
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
收回本帖的言论,已经被小曹同学鉴定过的了

[ 本帖最后由 wp231957 于 2012-12-8 11:21 编辑 ]

DO IT YOURSELF !
2012-12-08 11:03
CRUISEQUAN
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2012-12-7
收藏
得分:0 
回复 5楼 wp231957
谢谢
2012-12-08 11:14
czz5242199
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:4
帖 子:660
专家分:2400
注 册:2011-10-26
收藏
得分:3 
这个不是筛选法,这个是最最原始的试除法
2012-12-08 11:17
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
以下是引用czz5242199在2012-12-8 11:17:59的发言:

这个不是筛选法,这个是最最原始的试除法
汗,指导错误

DO IT YOURSELF !
2012-12-08 11:19
CRUISEQUAN
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2012-12-7
收藏
得分:0 
回复 6楼 CRUISEQUAN
那麻烦你给个筛选法,对了别用指针我还没学
2012-12-08 12:22
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:3 
回复 9楼 CRUISEQUAN
    for (i = 2;i <= Max;i++)
        if (!b[i - 1])
            for (j = i + i;j <= Max;j += i)
                b[j - 1] = 1;


[fly]存在即是合理[/fly]
2012-12-08 12:42
快速回复:这个筛选法求素数看不懂啊,你们指点一下吧
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.028661 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved