标题:找素数,有比Eratosthenes筛选法更快的算法吗?
只看楼主
xxwpk007
Rank: 4
等 级:业余侠客
帖 子:166
专家分:289
注 册:2007-7-29
结帖率:100%
 问题点数:0 回复次数:2 
找素数,有比Eratosthenes筛选法更快的算法吗?
大家有什么好算法。。

程序代码:
#include <stdio.h>
#define MAX 100

int main(void)
{
    int i;
    int j;
    char table[MAX];
    
    for(i = 2;i < MAX;i++)
        table[i] = 1;
    for(i = 2;i < MAX;i++)
        if(table[i] == 1)
            for(j = i;i*j < MAX;j++)
                table[i*j] = 0;
    for(i = 2;i < MAX;i++)
        if(table[i] == 1)
            printf("%d\n",i);

    return 0;
}
搜索更多相关主题的帖子: 素数 Eratosthenes 算法 筛选 
2010-10-21 22:26
pangding
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:北京
等 级:贵宾
威 望:94
帖 子:6784
专家分:16751
注 册:2008-12-20
得分:0 
找要看所谓的“找”是什么意思了。如果你想求多少以内全部的素数,这个方法应该算是挺快的了。至少我不知道还有什么比较有效的算法。

但比如说在一个范围内找出一个素数呀,找一个比一个已知的数大的不多(就是指找比他大的可能是最小)的一个素数呀,之类的问题,就没必要用这个算法。
2010-10-21 23:35
pangding
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:北京
等 级:贵宾
威 望:94
帖 子:6784
专家分:16751
注 册:2008-12-20
得分:0 
处理素的高级算法,都有点连蒙带猜的性质。就说是它只能给出一个倾向是素数的数,或某个数是否以极大的概率是素数。
素数检测是个 NPC 问题,没有有效的算法。
2010-10-21 23:40



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




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

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