在我们需要判断一个数是否是素数的时候,最容易想到的就是那个熟悉的O(√n)的算法。那个算法非常的简单易懂,但如果我们仔细想想,当n这个数字很大的时候,这个算法其实是不够用的,时间复杂度会相对比较高。

  怎么解决呢?我们先来了解一下“费马小定理”。假设我们有一个素数p,且另一个数a和p互素,就可以得到ap-1≡1(mod p)。这个定理很巧妙啊,有人就想了,能不能通过费马小定理来判断一个数是否是素数呢?也就是说,当我们判断一个数p是否是素数时,只需要判断ap-1≡1(mod p)是否成立即可。这里的a因为是任意数,干脆就让它等于2,那么判断一个数p是否是素数就转化成了判断2p-1≡1(mod p)是否成立。乍一看,这好像没什么问题。当这个式子不成立时,p一定是一个合数,这没毛病;但是当式子成立的时候p就一定是素数吗?我们举个反例。当p = 341时,2340≡1(mod 341)成立,然而很不巧,341 = 11 * 31是一个纯正的合数。这就是数学中所说的,对于所有的a都存在对应的伪素数。(ps:这个问题并不能完全通过改变基数解决)

  那我们该怎么办呢?其实很简单,只需要进行“二次探测”把伪素数揪出来就ok了。这可不是乱改,是有依据的:当p为素数时,方程x2≡1(mod p)有两个根 x = 1 和 x = p - 1。这两个根被我们赋予了一个奇怪的名字:平凡平方根。那么,判断一个数p是否是素数这个问题就又被我们转化,变成了判断在模p意义下是否存在1的非平凡平方根,若存在则p为合数,反之则为素数。这一测试被我们“亲切地”称为“Miller - Rabin测试”。

  具体操作步骤如下:

  ①选取多个基数a进行测试;

  ②寻找模p为1的非平凡平方根;令p - 1 = 2t*u(t >= 1, u为奇数),ap-1 = a2t*u = a2t  ,先算出x=au (mod p),再把 x 平方 t 次,每次模上 p,这样我们就得到了一个长度为 t + 1 的序列。我们希望这个序列以 1 结尾。若中间某一项为 1,则这一项的前一项必须为 1 或 n - 1,否则p就是合数。

  在Miller - Rabin测试中进行s次测试,这并不代表这项测试是简单地验证费马小定理,它大大降低了出错的概率,研究表明,Miller - Rabin测试的出错概率至多为 2-s 这可以说是非常小了。所以不用担心它的准确度和严谨性。

#include<bits/stdc++.h>
using namespace std; int pow(long long a, long long b, long long n) {
long long ans = ;
while (b) {
if (b & ) {
ans = ans * a % n;
}
a = a * a % n;
b >>= ;
}
return ans;
} bool judge(long long n, long long a) {
long long u = , t = n - ;
while (t % == ) {u++; t /= ;}
long long x = pow(a, t, n); for (int i = ; i <= u; i++) {
long long nx = x * x % n;
if ((nx == ) && (x != ) && (x != n - ))
return true;
x = nx;
}
if (x != ) return true;
return false;
} bool miller(long long n, int s) {
if (n == ) return true;
if (n < || n % == ) return false;
for (int i = ; i <= s; i++) {
long long a = rand() % (n - ) + ;
if (judge(n, a)) return false;
}
return true;
} int main() {
int t;
cin >> t;
long long a;
while (t--) {
cin >> a;
if (miller(a, )) {
cout << "yes" << endl;
}
else cout << "no" << endl;
}
return ;
}

与数论的爱恨情仇--01:判断大素数的Miller-Rabin的更多相关文章

  1. pytorch和tensorflow的爱恨情仇之定义可训练的参数

    pytorch和tensorflow的爱恨情仇之基本数据类型 pytorch和tensorflow的爱恨情仇之张量 pytorch版本:1.6.0 tensorflow版本:1.15.0 之前我们就已 ...

  2. 注解:大话AOP与Android的爱恨情仇

    转载:大话AOP与Android的爱恨情仇 1. AOP与OOP的区别 平时我接触多的就是OOP(Object Oriented Programming面向对象).AOP(Aspect Oriente ...

  3. pytorch和tensorflow的爱恨情仇之参数初始化

    pytorch和tensorflow的爱恨情仇之基本数据类型 pytorch和tensorflow的爱恨情仇之张量 pytorch和tensorflow的爱恨情仇之定义可训练的参数 pytorch版本 ...

  4. Menu与ActionBar的爱恨情仇

    最近在开发一款音乐播放器,在开发过程中遇到了一点小麻烦,通过android API搞清楚了Menu与ActionBar的爱恨情仇,写了个小Demo祭奠一下那些年我们陷进去的坑,有不对的地方请大神们批评 ...

  5. web移动端fixed布局和input等表单的爱恨情仇 - 终极BUG,完美解决

    [问题]移动端开发,ios下当fixed属性和输入框input(这里不限于input,只要可以调用移动端输入法的都包括,如:textarea.HTML5中contenteditable等),同时存在的 ...

  6. 除了love和hate,还能怎么表达那些年的“爱恨情仇”?

    实用英语 帮你全面提高英语水平 关注 童鞋们每次刷美剧的时候,相信都会被CP感满满的男女主角虐得体无完肤吧. 可是,一到我们自己表达爱意或者恨意的时候,却苦于词穷,只会用love, like, hat ...

  7. 对json的爱恨情仇

    本文回想了对json的爱恨情仇. C++有风险,使用需慎重. 本文相关代码在:http://download.csdn.net/detail/baihacker/7862785 当中的測试数据不在里面 ...

  8. String、StringBuilder、StringBuffer的爱恨情仇

    第三阶段 JAVA常见对象的学习 StringBuffer和StringBuilder类 (一) StringBuffer类的概述 (1) 基本概述 下文以StringBuffer为例 前面我们用字符 ...

  9. [转帖]探秘华为(一):华为和H3C(华三)的爱恨情仇史!

    探秘华为(一):华为和H3C(华三)的爱恨情仇史! https://baijiahao.baidu.com/s?id=1620703498823290828&wfr=spider&fo ...

随机推荐

  1. Java实验案例(接口)

    实验任务 任务一:设计实现发声接口 任务二:动物乐园 实验内容 任务一:设计实现发声接口 任务目的: 理解并掌握如何定义接口 掌握接口的实现方式 任务描述: 设计和实现一个Soundable接口,该接 ...

  2. RadioGroup实现类似ios的分段选择(UISegmentedControl)控件

    在ios7中有一种扁平风格的控件叫做分段选择控件UISegmentedControl,控件分为一排,横放着几个被简单线条隔开的按钮,每次点击只能选择其中一个按钮,他类似于tabbar但是又稍微有点区别 ...

  3. 【Python】Java程序员学习Python(三)— 基础入门

    一闪一闪亮晶晶,满天都是小星星,挂在天上放光明,好像许多小眼睛.不要问我为什么喜欢这首歌,我不会告诉你是因为有人用口琴吹给我听. 一.Python学习文档与资料 一般来说文档的资料总是最权威,最全面的 ...

  4. Typescript 基础知识

    Typescript 就是 Javascript 的超集,所以首先你要知道 Javascript 基础知识 类型注解 类型注解在TypeScript中是记录函数或变量约束的简便方法. // 布尔值 l ...

  5. zTree自定义节点name显示样式

    //setting中配置属性 view: { showLine:false, dblClickExpand: true, showIcon: false, addDiyDom: addDiyDom / ...

  6. iframe内联框

    内联框中表格的下划线老是显示不出来,设置宽度百分比不起作用,调整了文本域的宽度也不行.只能动态调整iframe的高度.

  7. Linux su命令详解

    su switch user,用于切换用户用 su常见命令参数 用法:su [选项]... [-] [用户 [参数]... ] Change the effective user id and gro ...

  8. Hadoop HBase概念学习系列之物理视图(又名为物理模型)(九)

    虽然,从HBase的概念视图来看,每个表格是由很多行组成的,但是在物理存储上面,它是按照列来保存的,这一点在进行数据设计和程序开发的时候必须牢记. 在物理存储上面,它是按照列来保存的 需要注意的是,在 ...

  9. IP地址编址

    比特:一比特就是一个数字,1或者0. 字节:以字节是7比特或者8比特,取决于是否使用奇偶校验 八位组:8比特构成 网络地址:用来将数据包发送到远端网路 比如10.0.0.0 广播地址:将信息发送给网络 ...

  10. Alpha 冲刺报告(5/10)

    Alpha 冲刺报告(5/10) 队名:洛基小队 峻雄(组长) 已完成:修改角色的移动脚本 明日计划:完善此项脚本 剩余任务:角色的属性脚本 困难:没有时间,代码的编写时间太慢 ----------- ...