首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >找到第一个素数?

找到第一个素数?
EN

Stack Overflow用户
提问于 2011-02-06 05:28:18
回答 5查看 5.3K关注 0票数 6

可能重复: 在python中列出N以下所有素数的最快方法

虽然我已经编写了一个函数来查找n (primes(10) -> [2, 3, 5, 7])下的所有素数,但我很难找到找到第一个n素数的快速方法。最快的方法是什么?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2011-02-06 05:35:24

从估计g(n) = n log n + n log log n*开始,它估计n> 5的n个素数的大小。

然后在估计值上做个筛子。g(n)给出了一个过高的估计,这是可以的,因为我们可以简单地丢弃生成的额外素数,这些素数大于所需的n。

然后考虑一下"在python中列出N以下所有素数的最快方法“中的答案。

如果您关心代码的实际运行时(而不是算法的时间复杂度的数量级),请考虑使用使用numpy的解决方案之一(而不是“纯python”解决方案)。

*当我写log时,我指的是自然对数。

票数 8
EN

Stack Overflow用户

发布于 2011-02-06 05:49:36

根据,第n个素数p_n满足

p_n

N >= 6

因此,如果您使用大于右方的下一个整数来运行当前函数(例如,其他答案中提到的一个筛子),则可以确保找到第n个素数。

票数 5
EN

Stack Overflow用户

发布于 2011-02-06 05:34:10

你想要埃拉托斯提尼筛

使用π函数估计n的值,稍微超调,然后使用一个筛子计算到需要的点。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4911777

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档