前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Sweet Snippet 系列之 埃拉托斯特尼(Eratosthenes)筛法

Sweet Snippet 系列之 埃拉托斯特尼(Eratosthenes)筛法

作者头像
用户2615200
发布2019-07-08 17:42:33
6350
发布2019-07-08 17:42:33
举报

埃拉托斯特尼(Eratosthenes)筛法的简单实现

遴选素数的埃拉托斯特尼(Eratosthenes)筛法想必大家都不陌生,不熟悉的朋友可以看看wiki,在此简单列出一份代码实现(Lua)

代码语言:javascript
复制
function Eratosthenes(n)
    local is_prime = {}
    
    -- init is_prime map
    for i = 2, n do
        is_prime[i] = true
    end
    
    -- eratosthenes filter
    local beg_val = 2
    local end_val = math.floor(math.sqrt(n))
    
    for i = beg_val, end_val do
        if is_prime[i] then
            for j = i + i, n, i do
                is_prime[j] = false
            end
        end
    end
    
    -- get primes
    local primes = {}
    for i = 2, n do
        if is_prime[i] then
            table.insert(primes, i)
        end
    end
    
    return primes
end

简单测试一下:

代码语言:javascript
复制
print(#Eratosthenes(100)) // output 25

100 以内的素数是 25 个,有兴趣的朋友可以试试到底是哪 25 个~

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年07月04日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
腾讯云服务器利旧
云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档