首页 后端开发 Python教程 查找给定整数 N 以下的所有素数的最快方法是什么?

查找给定整数 N 以下的所有素数的最快方法是什么?

Dec 23, 2024 am 09:45 AM

What's the Fastest Way to Find All Prime Numbers Below a Given Integer N?

列出 N 以下所有素数的最快方法

此代码片段提供了有效生成素数列表的方法的 Python 实现最多给定整数。

    def get_primes(n):
        numbers = set(range(2, n + 1))
        primes = []
        while numbers:
            p = numbers.pop()
            primes.append(p)
            numbers.difference_update(set(range(p * p, n + 1, p)))
        return primes
登录后复制

时间复杂度:

给定代码的时间复杂度为 O(n log log n),因为它使用埃拉托斯特尼筛法来计算素数。

实现说明:

  • 代码初始化一组数字,其中包含从 2 到n.
  • 它通过将尚未标记的最小数字的所有倍数标记为合数,迭代地从数字中删除非素数。在更新数字时,通过采用当前素数的步幅来跳过这些倍数。
  • 当数字为空时,代码停止,找到的素数列表以素数形式返回。

潜在问题:

实现中存在一个潜在问题,它将起始数字标记为素数当它只应考虑从 2 到 n 的数字时。这可以通过从 2 而不是 0 开始循环来解决。

用法:

要使用此实现,您可以调用 get_primes 函数并传递所需的上限绑定为参数。例如,要查找 1000 以内的所有素数,您可以使用:

primes = get_primes(1000)
登录后复制

输出:

代码的输出将是素数列表最大到指定整数的数字。例如,运行 n = 1000 的代码将产生以下输出:

[2, 3, 5, 7, 11, 13, 17, 19, 23, 29, ..., 977]

以上是查找给定整数 N 以下的所有素数的最快方法是什么?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何使用Python查找文本文件的ZIPF分布 如何使用Python查找文本文件的ZIPF分布 Mar 05, 2025 am 09:58 AM

如何使用Python查找文本文件的ZIPF分布

如何在Python中下载文件 如何在Python中下载文件 Mar 01, 2025 am 10:03 AM

如何在Python中下载文件

python中的图像过滤 python中的图像过滤 Mar 03, 2025 am 09:44 AM

python中的图像过滤

我如何使用美丽的汤来解析HTML? 我如何使用美丽的汤来解析HTML? Mar 10, 2025 pm 06:54 PM

我如何使用美丽的汤来解析HTML?

如何使用Python使用PDF文档 如何使用Python使用PDF文档 Mar 02, 2025 am 09:54 AM

如何使用Python使用PDF文档

如何在django应用程序中使用redis缓存 如何在django应用程序中使用redis缓存 Mar 02, 2025 am 10:10 AM

如何在django应用程序中使用redis缓存

引入自然语言工具包(NLTK) 引入自然语言工具包(NLTK) Mar 01, 2025 am 10:05 AM

引入自然语言工具包(NLTK)

如何使用TensorFlow或Pytorch进行深度学习? 如何使用TensorFlow或Pytorch进行深度学习? Mar 10, 2025 pm 06:52 PM

如何使用TensorFlow或Pytorch进行深度学习?

See all articles