Python计算素数个数的两种方法

 更新时间:2023年05月19日 09:10:19   作者:机器学习Zero  
本文主要介绍了Python计算素数个数的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

素数(prime number)也叫质数,为大于1的且除1和本身以外不再有其他因数的自然数,与之相对的是合数,素数有无限个。

计算小于N的素数个数

  • 输入: 10
  • 输出: 4

小于10的素数共4个:2, 3, 5, 7

方法一:直接判断

from math import sqrt
def isPrime(n):
    for i in range(2,int(sqrt(n))+1):
        if n%i==0:
            return False
    return True
def countPrime(N):
    if N<3:
        return 0
    else:
        cou = 1
        for i in range(3,N,2):
            if isPrime(i):
                cou += 1
    return cou
print(countPrime(2))
print(countPrime(5))
print(countPrime(100))
print(countPrime(100000))  
print(countPrime(10000000))#在n>100000000时达到计算瓶颈

输出:

0
2
25
9592
664579

方法二:埃氏筛法

埃拉托色尼筛选法(the Sieve of Eratosthenes)简称埃氏筛法,是古希腊数学家埃拉托色尼(Eratosthenes 274B.C.~194B.C.)提出的一种筛选法。

要得到自然数n以内的全部素数,必须把不大于n的所有素数的倍数剔除,剩下的就是素数,具体步骤如下:先用2去筛,即把2留下,把2的倍数剔除掉;再用下一个质数,也就是3筛,把3留下,把3的倍数剔除掉;接下去用下一个质数5筛,把5留下,把5的倍数剔除掉;不断重复下去。

def couPrime(N):
    primeList = [True]*N
    for i in range(2,N):
        if(primeList[i]):
            for j in range(2*i,N,i):
                primeList[j]=False
    cou = primeList.count(True)-2
    return cou
print(couPrime(100000000)) #在n>1000000000达到计算瓶颈

输出:

5761455

到此这篇关于Python计算素数个数的实现的文章就介绍到这了,更多相关Python计算素数个数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • conda虚拟环境中查看包的位置的四种方法

    conda虚拟环境中查看包的位置的四种方法

    本文主要介绍了conda虚拟环境中查看包的位置的四种方法,包括使用Conda命令、在Python中查看、使用pip命令以及检查环境目录结构,具有一定的参考价值,感兴趣的可以了解一下
    2025-03-03
  • Pandas DataFrame数据的更改、插入新增的列和行的方法

    Pandas DataFrame数据的更改、插入新增的列和行的方法

    这篇文章主要介绍了Pandas DataFrame数据的更改、插入新增的列和行的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-06-06
  • Python使用fliecmp实现比较文件的操作

    Python使用fliecmp实现比较文件的操作

    对于文件的比较一般有几种,比如比较文件的内容,比较文件的大小,或者直接对比整个项目文件,本文就详细的介绍这些方法的实现,感兴趣的可以了解一下
    2021-06-06
  • Python中的单下划线和双下划线使用场景详解

    Python中的单下划线和双下划线使用场景详解

    这篇文章主要介绍了Python中的单下划线和双下划线使用场景详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • Python包管理利器之pip命令的安装与使用入门指南

    Python包管理利器之pip命令的安装与使用入门指南

    pip是Python的包管理工具,全称为"Pip Installs Packages",是Python生态系统中最重要的工具之一,下面就跟随小编一起深入了解下pip命令的安装与使用吧
    2025-04-04
  • Python使用单例模式创建类的实现示例

    Python使用单例模式创建类的实现示例

    本文详细介绍了Python中实现单例模式的多种方式,包括元类、threading.Lock、模块、importlib、__new__方法和装饰器等,感兴趣的可以了解一下
    2024-12-12
  • 快速了解Python相对导入

    快速了解Python相对导入

    这篇文章主要介绍了快速了解Python相对导入,具有一定借鉴价值,需要的朋友可以参考下
    2018-01-01
  • 利用Python和C++实现解析gltf文件

    利用Python和C++实现解析gltf文件

    gltf是类似于stl、obj、ply等常见的3D对象存储格式,它被设计出来是为了便于渲染的数据转换和传输,本文为大家介绍了使用Python和C++解析gltf文件的方法,感兴趣的可以了解下
    2023-09-09
  • Python中处理表格数据的Tablib库详解

    Python中处理表格数据的Tablib库详解

    这篇文章主要介绍了Python中处理表格数据的Tablib库详解,Tablib 是一个 MIT 许可的格式不可知的表格数据集库,用 Python 编写,它允许您导入、导出和操作表格数据集,需要的朋友可以参考下
    2023-08-08
  • 对pycharm代码整体左移和右移缩进快捷键的介绍

    对pycharm代码整体左移和右移缩进快捷键的介绍

    今天小编就为大家分享一篇对pycharm代码整体左移和右移缩进快捷键的介绍,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-07-07

最新评论