素数检验方法

一、费马小定理

如果 p 是一个素数,并且 a 是一个整数,满足 1<a<p,(即 a 与 p 互质)那么以下同余式成立:

​​​​​​​ ​​​​​​​ ​​​​​​​ ​​​​​​​

二、费马素数检验

如果存在一个整数 a,使得

​​​​​​​ ​​​​​​​

那么 n 一定不是素数

三、Carmichael

费马素数检验最大的缺陷在于存在一种特殊的合数

最小的卡迈克尔数是 561=3×11×17

因此,费马检验无法将561识别为合数。

四、欧拉准则

这里要用到先前文章(二次同余式和平方剩余)的勒让德符号

如果 p 是一个奇素数,并且 a 是一个与 p 互质的整数(即 gcd⁡(a,p)=1),那么

​​​​​​​ ​​​​​​​ ​​​​​​​ ​​​​​​​

结果为1, a 是模 p 的二次剩余 ;结果为-1,a 是模 p 的二次非剩余

五、欧拉拟素数检验

这个方法能够检测Carmichael!!!

六、Miller-Rabin强拟素数检验

这是目前最强大、最广泛使用的概率性素数检验算法

具体操作步骤可以参考: https://www.bilibili.com/video/BV1T44y1Z7Gx

相关推荐
智驱力人工智能1 分钟前
一盔一带AI抓拍系统能否破解非机动车执法取证难 骑行未戴头盔检测 电动车未戴头盔智能监测 摩托车头盔佩戴AI识别系统 边缘计算实时处理
人工智能·算法·yolo·目标检测·边缘计算
重生之我是Java开发战士4 分钟前
【优选算法】优先级队列:最后一块石头的重量,数据流中的第K大元素,前K个高频单词,数据流中的中位数
数据结构·算法·leetcode
智算菩萨7 分钟前
音频处理基础理论:从物理声波到数字信号完整知识体系
算法·机器学习·电脑·音视频
小高求学之路1 小时前
计算机视觉、YOLO算法模型训练、无人机监测人员密集自动识别
算法·yolo·计算机视觉
散峰而望1 小时前
【基础算法】剪枝与记忆化搜索:算法优化的双刃剑,效率倍增的实战指南
算法·机器学习·剪枝
m0_748873551 小时前
C++与Rust交互编程
开发语言·c++·算法
2401_891482178 小时前
多平台UI框架C++开发
开发语言·c++·算法
88号技师9 小时前
2026年3月中科院一区SCI-贝塞尔曲线优化算法Bezier curve-based optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法
t198751289 小时前
三维点云最小二乘拟合MATLAB程序
开发语言·算法·matlab
x_xbx10 小时前
LeetCode:148. 排序链表
算法·leetcode·链表