标题:用筛选法求100之内的素数。求大神解释啊完全看不懂啊。(语句摘自百度文库) ...
只看楼主
涯无言
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2017-9-24
结帖率:100%
已结贴  问题点数:20 回复次数:6 
用筛选法求100之内的素数。求大神解释啊完全看不懂啊。(语句摘自百度文库)
//用筛选法求100之内的素数。
#include <stdio.h>
void main()
{
    int num[100],i,j;
    for (i=0;i<100;i++) num[i]=1;
    for (i=2;i<=10;i++)
        for (j=2;i*j<=100;j++) num[i*j-1]=0;
    printf("100以内的素数有:\n");
    for (i=j=0;i<100;i++)
        if (num[i]==1)   
        {
            printf("%-4d",i+1);
            if (++j%4==0)
            printf("\n");
}
}
搜索更多相关主题的帖子: 筛选 素数 num for i++ 
2017-09-24 22:13
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:20 
1、先假设100个数都为素数(标记1)
2、将不是素数的排除(标记0)
3、输出素数(标记为1的)
2017-09-24 22:46
涯无言
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2017-9-24
得分:0 
回复 2楼 吹水佬
还是不懂啊~~~
2017-09-27 22:20
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:0 
以下是引用涯无言在2017-9-27 22:20:12的发言:

还是不懂啊~~~

如:有10个数............ 2,3,4,5,6,7,8,9,10,11
先假设都是素数标记为1 .. 1,1,1,1,1,1,1,1, 1, 1
将不是素数的标记为0 .... 1,1,0,1,0,1,0,0, 0, 1
剩下标记为1的是素数 .... 2,3, ,5,, 7, , ,  ,11
2017-09-28 05:57
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:0 
100个数写纸上
将2的倍数(也就是4,6,8,……)划掉
将3的倍数(也就是6,9,12,……)划掉
将4的倍数(也就是8,12,16,……)划掉
……
将10的倍数(也就是20,30,40,……)划掉

这就是你代码的逻辑,不是很好
2017-09-28 08:32
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:0 
不用乘法:
#include <stdio.h>
void main()
{
    int num[100],i,j;
    for (i=0; i<100; i++) num[i]=1;
    i = 2;
    while (i<100)
    {
        for (j=i+i; j<100; j+=i)
            if (num[j])
                num[j]=0;
        for (j=i+1; num[j]==0&&j<100; ++j) NULL;
        i = j;
    }
    printf("100以内的素数有:\n");
    for (j=0,i=2; i<100; ++i)
    {
        if (num[i]==1)
        {
            ++j;
            printf("%-4d",i);
            if (j%4==0)
                printf("\n");
        }
    }
}
2017-09-28 08:59
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:0 
回复 5楼 rjsp
以下是引用rjsp在2017-9-28 08:32:29的发言:

100个数写纸上
将2的倍数(也就是4,6,8,……)划掉
将3的倍数(也就是6,9,12,……)划掉
将4的倍数(也就是8,12,16,……)划掉
……
将10的倍数(也就是20,30,40,……)划掉

这就是你代码的逻辑,不是很好

感觉所说逻辑不咋的的原因是很多数据重复计算了~
例如4是2的倍数遇到4时可以跳过……不过楼主代码把4也计算进去了……
筛法有两种~

其中埃拉特斯特尼筛法的时间复杂度是o(n*log(n))

而另一种欧拉筛法的时间复杂度为o(n);

所以如果要高效的筛法的话就用欧拉筛~



[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-09-28 19:08



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-480918-1-1.html




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

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