网站首页 > 技术文章 正文
大家好!我是幻化意识流。
当谈论素数相关算法时,以下是几个常见的算法,包括素数检测和生成素数序列。我将为你提供 Python 代码示例,并添加注释说明。
素数检测算法
方法一:试除法
def is_prime(num):
if num < 2:
return False
for i in range(2, int(num ** 0.5) + 1):
if num % i == 0:
return False
return True
注释说明:
is_prime 函数用于检测一个数是否为素数。
首先判断数是否小于 2,小于 2 的数都不是素数。
从 2 开始到平方根(取整)之间的数逐个试除,如果能整除,则不是素数,返回 False。
若循环结束仍然没有找到能整除的数,则说明是素数,返回 True。
方法二:Miller-Rabin 算法
import random
def is_prime(num, k=5):
if num < 2:
return False
if num in (2, 3):
return True
if num % 2 == 0:
return False
def check(a, s, d, n):
x = pow(a, d, n)
if x == 1 or x == n - 1:
return True
for _ in range(s - 1):
x = pow(x, 2, n)
if x == n - 1:
return True
return False
s, d = 0, num - 1
while d % 2 == 0:
s += 1
d //= 2
for _ in range(k):
a = random.randint(2, num - 2)
if not check(a, s, d, num):
return False
return True
注释说明:
is_prime 函数使用 Miller-Rabin 算法进行素数检测。
首先判断数是否小于 2,小于 2 的数都不是素数。
若数为 2 或 3,则为素数。
若数为偶数,则不是素数。
通过循环将数表示为 d * 2^s + 1 的形式。
对于给定的 k 值(默认为 5),选择 k 个随机数 a 进行检测。
check 函数用于执行 Miller-Rabin 算法的检测步骤,如果 a 的次方满足一定条件,则可能是素数。
若所有的随机数都通过检测,则返回 True,否则返回 False。
生成素数序列算法
方法一:埃拉托斯特尼筛法
def generate_primes(limit):
primes = [True] * (limit + 1)
primes[0] = primes[1] = False
p = 2
while p * p <= limit:
if primes[p]:
for i in range(p * p, limit + 1, p):
primes[i] = False
p += 1
prime_numbers = [num for num, is_prime in enumerate(primes) if is_prime]
return prime_numbers
注释说明:
generate_primes 函数用于生成小于等于给定限制值的素数序列。
创建一个布尔型列表 primes,初始化所有值为 True,用于标记素数。
将索引为 0 和 1 的位置设置为 False,因为它们不是素数。
从 2 开始循环到平方根小于等于限制值的数 p。
如果 p 是素数(primes[p] 为 True),则将 p 的倍数位置标记为 False。
循环结束后,所有为 True 的索引位置即为素数,将它们存储在列表 prime_numbers 中并返回。
这些是常见的素数相关算法的 Python 实现示例,你可以根据需要选择使用。
如果喜欢我的文章,麻烦动动您的大神之手帮我点个赞哦!本人在此深深的表示感谢!
猜你喜欢
- 2025-07-14 最大公约数怎么求?用这三种方法求解非常管用
- 2025-07-14 最大的素数发现了,跨越 4100 万位,打破了之前的记录超过 1600 万位
- 2025-07-14 数字找规律,很多人急得直跺脚,太难了!
- 2025-07-14 素数分布的解析理论:π(x)、Li(x)和J(x)的严格数学框架
- 2025-07-14 大多数人不知道的 16 个非常有趣的质数
- 2025-07-14 「C语言程序设计」C语言求回文素数
- 2025-07-14 欧几里得算法(欧几里得算法别称)
- 2025-07-14 C++刷题 搜索与回溯法解素数环(c++查找素数)
- 2025-07-14 Python:4种质数算法效率比较(python怎么算质数)
- 2025-07-14 一到六年级,数学运算能力差、薄弱知识点的原因和措施汇总!
- 最近发表
- 标签列表
-
- axure 注册码 (25)
- mutex_lock (30)
- oracleclient (27)
- nfs (25)
- springbatch (28)
- oracle数据库备份 (25)
- dir (26)
- connectionstring属性尚未初始化 (23)
- output (32)
- panel滚动条 (28)
- centos 5 4 (23)
- sql学习 (33)
- c 数组 (33)
- pascal语言教程 (23)
- ppt 教程 (35)
- java7 (24)
- 自适应网站制作 (32)
- server服务自动停止 (25)
- 超链接去掉下划线 (34)
- 什么是堆栈 (22)
- map entry (25)
- ubuntu装qq (25)
- outputstreamwriter (26)
- fill_parent (22)
- mssqlserver jar (30)