【算法基础】关于埃拉托色尼筛选法

这几天在学习算法和数据结构,在学习基本数据结构数组的时候(数组就是最基本的数据结构),偶然看到了一种利用数组求素数的方法,就是用的埃拉托色尼筛选法

那么埃拉托色尼筛选法到底是什么方法呢?

埃拉托色尼选筛法(the Sieve of Eratosthenes)简称埃氏筛法,是古希腊数学家 埃拉托色尼(Eratosthenes 274B.C.~194B.C.)提出的一种筛选法。 是针对自然数列中的自然数而实施的,用于求一定范围内的 质数,它的容斥原理之完备性条件是p=H~(粘贴百度词条的,将就着看)

具体的思想是这样的,假定我们要求一定范围内的素数,那么我可以这样做:

从2开始,在范围内把2的倍数删除或者标记,然后再给2加1,在范围内再删除3的倍数,以此类推,直到需求的范围内所有的数均删除或读取

代码如下:

#define N 1000
int main() {
    int i, j, arr[N];
    memset(arr, 1, N);
    for(i = 2; i < N; ++i) {
        if(arr[i]) {
        /*把当前数的倍数都给标记为0*/
            for(j = i; i < N; ++j) {
                a[i * j] = 0;
            }
        }
        //打印当前数
        for(i = 2; i < N; ++i) {
            if(a[i])printf("%2d",i);
        }
        printf("\n");
    }
}
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值