埃拉托斯特尼筛法:在 Python 中优化素数生成
埃拉托斯特尼筛法是寻找素数的经典算法。然而,正确实现它以避免性能瓶颈至关重要。
原始实现
提供的 primes_sieve 函数维护候选素数列表并迭代删除非素数通过遍历列表并消除因子来求素。由于列表操作的成本很高,这种方法本质上效率很低。
基于字典的优化
改进的 primes_sieve1 函数使用字典来存储素性标志。虽然比基于列表的方法更快,但它仍然面临挑战。它以未定义的顺序迭代字典,导致非素数因子的冗余标记。此外,它将最终的字典转换为列表,从而产生不必要的开销。
正确且高效的实现
正确的埃拉托斯特尼筛法算法利用布尔标志列表来表明素性。 primes_sieve2 函数将所有数字的标志初始化为 True,并将 0 和 1 的标志设置为 False。它迭代列表,通过将标志设置为 False 来标记非素数。
这种方法很有效,因为:
- 它使用列表而不是字典,避免了开销键值运算。
- 仅将质因数标记为非质数,减少冗余操作。
- 它通过从每个素数的平方而不是其双倍开始来优化标记过程。
通过正确实施埃拉托斯特尼筛法,您可以显着提高素数生成的性能,使其甚至适用于输入限制较大,例如查找 200 万以下的素数。
以上是我们如何优化埃拉托斯特尼筛法以在 Python 中高效生成素数?的详细内容。更多信息请关注PHP中文网其他相关文章!

Linux终端中查看Python版本时遇到权限问题的解决方法当你在Linux终端中尝试查看Python的版本时,输入python...

本文解释了如何使用美丽的汤库来解析html。 它详细介绍了常见方法,例如find(),find_all(),select()和get_text(),以用于数据提取,处理不同的HTML结构和错误以及替代方案(SEL)

Python的statistics模块提供强大的数据统计分析功能,帮助我们快速理解数据整体特征,例如生物统计学和商业分析等领域。无需逐个查看数据点,只需查看均值或方差等统计量,即可发现原始数据中可能被忽略的趋势和特征,并更轻松、有效地比较大型数据集。 本教程将介绍如何计算平均值和衡量数据集的离散程度。除非另有说明,本模块中的所有函数都支持使用mean()函数计算平均值,而非简单的求和平均。 也可使用浮点数。 import random import statistics from fracti

本文比较了Tensorflow和Pytorch的深度学习。 它详细介绍了所涉及的步骤:数据准备,模型构建,培训,评估和部署。 框架之间的关键差异,特别是关于计算刻度的

本文讨论了诸如Numpy,Pandas,Matplotlib,Scikit-Learn,Tensorflow,Tensorflow,Django,Blask和请求等流行的Python库,并详细介绍了它们在科学计算,数据分析,可视化,机器学习,网络开发和H中的用途

本文指导Python开发人员构建命令行界面(CLIS)。 它使用Typer,Click和ArgParse等库详细介绍,强调输入/输出处理,并促进用户友好的设计模式,以提高CLI可用性。

在使用Python的pandas库时,如何在两个结构不同的DataFrame之间进行整列复制是一个常见的问题。假设我们有两个Dat...

文章讨论了虚拟环境在Python中的作用,重点是管理项目依赖性并避免冲突。它详细介绍了他们在改善项目管理和减少依赖问题方面的创建,激活和利益。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3汉化版
中文版,非常好用

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

禅工作室 13.0.1
功能强大的PHP集成开发环境

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

WebStorm Mac版
好用的JavaScript开发工具