Python计算质数的多种方法

更多学习内容

质数(Prime Number)是指大于1且只能被1和自身整除的正整数。计算质数是数论中的一个经典问题,也在编程中常常出现。

本文将介绍多种计算质数的方法,从最基础的方法到更高效的算法,以及一些Python中的优化技巧。

一、基础方法

1.1 暴力法

最简单的方法是使用暴力法,逐个检查每个正整数是否为质数。这种方法对于小数字是有效的,但在大数字上效率很低。

def is_prime(n):
    if n <= 1:
        return False
    for i in range(2, n):
        if n % i == 0:
            return False
    return True

1.2 优化暴力法

可以通过减少检查的范围来优化暴力法。因为质数必定大于1,所以只需检查2到√n之间的数是否能整除n。

import math

def is_prime(n):
    if n <= 1:
        return False
    if n == 2:
        return True
    if n % 2 == 0:
        return False
    for i in range(3, int(math.sqrt(n)) + 1, 2):
        if n % i == 0:
            return False
    return True

二、更高效的方法

2.1 埃拉托斯特尼筛法(Sieve of Eratosthenes)

埃拉托斯特尼筛法是一种高效的方法,用于生成一定范围内的所有质数。它通过不断排除合数来找到质数。

def sieve_of_eratosthenes(n):
    is_prime = [True] * (n + 1)
    is_prime[0] = is_prime[1] = False
    p = 2
    while p**2 <= n:
        if is_prime[p]:
            for i in range(p**2, n + 1, p):
                is_prime[i] = False
        p += 1
    primes = [i for i in range(2, n + 1) if is_prime[i]]
    return primes

2.2 Miller-Rabin素数测试

Miller-Rabin素数测试是一种概率性的方法,用于测试一个数是否为质数。虽然它不是绝对确定的,但通常可以提供可接受的结果。

import random

def miller_rabin(n, k=5):
    if n <= 1:
        return False
    if n <= 3:
        return True
    if n % 2 == 0:
        return False
    
    # 将n-1表示为(2^r) * d
    r, d = 0, n - 1
    while d % 2 == 0:
        r += 1
        d //= 2
    
    def witness(a, d, n):
        x = pow(a, d, n)
        if x == 1 or x == n - 1:
            return True
        for _ in range(r - 1):
            x = pow(x, 2, n)
            if x == n - 1:
                return True
        return False
    
    for _ in range(k):
        a = random.randint(2, n - 2)
        if not witness(a, d, n):
            return False
    return True

三、Python中的质数计算

Python标准库提供了一些用于计算质数的函数和模块,例如sympymath

3.1 使用sympy模块

sympy是Python中用于符号数学的强大库,它包含了许多数论函数,包括判断质数的函数。

from sympy import isprime

print(isprime(17))  # 输出:True

3.2 使用math模块

math模块提供了一些数学函数,包括sqrt函数,可以用来优化暴力法中的质数判断。

import math

def is_prime(n):
    if n <= 1:
        return False
    if n == 2:
        return True
    if n % 2 == 0:
        return False
    for i in range(3, int(math.sqrt(n)) + 1, 2):
        if n % i == 0:
            return False
    return True

总结

计算质数是数学和计算机科学中的一个经典问题,涉及多种算法和技术。本文介绍了计算质数的多种方法,包括基础方法、更高效的方法和Python中的内置函数和模块。选择合适的方法取决于具体的需求和性能要求。


---------------------------END---------------------------

题外话

感谢你能看到最后,给大家准备了一些福利!

感兴趣的小伙伴,赠送全套Python学习资料,包含面试题、简历资料等具体看下方。


👉CSDN大礼包🎁:全网最全《Python学习资料》免费赠送🆓!(安全链接,放心点击)

一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。

img

二、Python兼职渠道推荐*

学的同时助你创收,每天花1-2小时兼职,轻松稿定生活费.
在这里插入图片描述

三、最新Python学习笔记

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

img

四、实战案例

纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

img

👉CSDN大礼包🎁:全网最全《Python学习资料》免费赠送🆓!(安全链接,放心点击)

若有侵权,请联系删除

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值