题目链接: http://poj.org/problem?id=1811

题意: 判断一个数 n (2 <= n < 2^54)是否为质数, 是的话输出 "Prime", 否则输出其第一个质因子.

思路: 大数质因子分解, 直接用 pollard_rho (详情参见: http://blog.csdn.net/maxichu/article/details/45459533) 模板即可.

代码:

 #include <iostream>
#include <algorithm>
#define ll long long
using namespace std; const int MAXN = 1e2;
const int repeat = ;//repeat为检测次数,判断错误率为4^-repeat,一般8~10就够了 ll get_mult(ll a, ll b, ll c){//返回a*b%c
a %= c;
b %= c;
ll ret = ;
while(b){
if(b & ){
ret += a;
if(ret >= c) ret -= c;
}
b >>= ;
a <<= ;
if(a >= c) a -= c;
}
return ret;
} ll get_pow(ll x, ll n, ll mod){//返回x^n%mod
ll ret = ;
x %= mod;
while(n){
if(n & ) ret = get_mult(ret, x, mod);
x = get_mult(x, x, mod);
n >>= ;
}
return ret;
} //通过 a^(n-1) = 1(mod n) 来判断n是否为素数
//n-1 = x*2^t 中间使用二次探测定理
//是合数返回true,不一定是合数返回false
bool cherk(ll a, ll n, ll x, ll t){
ll ret = get_pow(a, x, n);
ll last = ret;
for(int i = ; i <= t; i++){
ret = get_mult(ret, ret, n);
if(ret == && last != && last != n - ) return true;
last = ret;
}
if(ret != ) return true;
return false;
} bool Miller_Rabin(ll n){
if(n < ) return false;
if(n == ) return true;
if(!(n & )) return false;//偶数
ll x = n - , t = ;
while(!(x & )){
x >>= ;
t++;
}
// srand(time(NULL));
for(int i = ; i < repeat; i++){
ll a = rand() % (n - ) + ;
if(cherk(a, n, x, t)) return false;
}
return true;
} ll factor[MAXN];
int tot;//n的质因子个数 ll get_gcd(ll a, ll b){
ll tmp;
while(b){
tmp = a;
a = b;
b = tmp % b;
}
return a >= ? a : -a;
} ll pollard_rho(ll x, ll c){//返回x的一个因子
ll i = , k = ;
// srand(time(NULL));
ll x0 = rand() % (x - ) + ;
ll y = x0;
while(){
i++;
x0 = (get_mult(x0, x0, x) + c) % x;
ll d = get_gcd(y - x0, x);
if(d != && d != x) return d;
if(y == x0) return x;
if(i == k){
y = x0;
k += k;
}
}
} void findfac(ll n, int k){//对n质因分解并将结果保存到factor中
if(n == ) return;
if(Miller_Rabin(n)){
factor[tot++] = n;
return;
}
ll p = n;
int c = k;//c防止死循环
while(p >= n){
p = pollard_rho(p, c--);
}
findfac(p, k);
findfac(n / p, k);
} int main(void){
ll n;
int t;
cin >> t;
while(t--){
cin >> n;
if(Miller_Rabin(n)) cout << "Prime" << endl;
else{
tot = ;
findfac(n, );
ll sol = factor[];
for(int i = ; i < tot; i++){
sol = min(sol, factor[i]);
}
cout << sol << endl;
}
}
return ;
}

poj1811(pollard_rho模板)的更多相关文章

  1. POJ-1811-Prime Test(pollard_rho模板,快速找最小素因子)

    题目传送门 sol:Pollard_Rho的模板题,刚看了Pollard_Rho和Miller_Rabin很多原理性的东西看不懂,只是记住了结论勉强能敲代码. Pollard_Rho #include ...

  2. HDU-3864 D_num Miller_Rabin和Pollard_rho

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3864 题意:给定一个数n,求n的因子只有四个的情况. Miller_Rabin和Pollard_rho ...

  3. POJ 2429

    思路:a/n*b/n=lcm/gcd 所以这道题就是分解ans.dfs枚举每种素数情况.套Miller_Rabin和pollard_rho模板 //#pragma comment(linker, &q ...

  4. 模板题Pollard_Rho大数分解 A - Prime Test POJ - 1811

    题意:是素数就输出Prime,不是就输出最小因子. #include <cstdio> #include<time.h> #include <algorithm> ...

  5. Pollard_Rho大数分解模板题 pku-2191

    题意:给你一个数n,  定义m=2k-1,   {k|1<=k<=n},并且 k为素数;  当m为合数时,求分解为质因数,输出格式如下:47 * 178481 = 8388607 = ( ...

  6. POJ1811 Prime Test(miller素数判断&&pollar_rho大数分解)

    http://blog.csdn.net/shiyuankongbu/article/details/9202373 发现自己原来的那份模板是有问题的,而且竟然找不出是哪里的问题,所以就用了上面的链接 ...

  7. 【POJ1811】【miller_rabin + pollard rho + 快速乘】Prime Test

    Description Given a big integer number, you are required to find out whether it's a prime number. In ...

  8. 【转】大素数判断和素因子分解【miller-rabin和Pollard_rho算法】

    集训队有人提到这个算法,就学习一下,如果用到可以直接贴模板,例题:POJ 1811 转自:http://www.cnblogs.com/kuangbin/archive/2012/08/19/2646 ...

  9. 数学#素数判定Miller_Rabin+大数因数分解Pollard_rho算法 POJ 1811&2429

    素数判定Miller_Rabin算法详解: http://blog.csdn.net/maxichu/article/details/45458569 大数因数分解Pollard_rho算法详解: h ...

随机推荐

  1. java代码。从来没想过java里的继承是多么的难懂。如哲学

    总结:实例.. 这里不加super("aaa",32); 运行:父类和子类的姓名,年龄是一样的.那这个super为什么没效果呢? 显示:class:Ji姓名是 小红年龄是:20课程 ...

  2. Task Crontab

    Crontab 1.查看任务 crontab -l 2.编辑任务 1)对应用户登录后编辑其下的作业 crontab -e 2)删除指定用户任务 crontab -u user -r 3)删除用户下指定 ...

  3. Oracle RMAN 学习:恢复

    Oracle RMAN 学习:恢复 6 rman恢复 Rman中的恢复对应restore,recover Restore,数据修复,利用备份集的数据文件来替换已损坏的数据文件或将其恢复到另外一个位置, ...

  4. 【OpenCV】基于图像处理和模式识别的火灾检测方法

    学期末一直忙考试,大作业,很久没来CSDN耕耘了... 虽然考试都结束了,手头还是累积了不少活儿要补,不多写了,晒个小项目,之前一直做的,后来当做模式识别课程的大作业交了. 大体框架如下: 还是之前的 ...

  5. Celery-4.1 用户指南: Calling Tasks(调用任务)

    基础 本文档描述 Celery 中任务实例和 Canvas 使用的统一 “Calling API”. API 中定义了一个执行选项的标准集,以及三个方法: - apply_async(args[, k ...

  6. 跨resetlogs不完全恢复- oracle自动reset错误incarnation

    在做oracle跨resetlogs的不完全恢复时,如果未删除flashback area的控制文件自动备份,那么Oracle可能会从控制文件自动备份中自动探测到incarnation信息,并重置in ...

  7. java 多线程系列基础篇(三)之start()和run()的区别

    概要 Thread类包含start()和run()方法,它们的区别是什么?本章将对此作出解答. start() 和 run()的区别说明 start() : 它的作用是启动一个新线程,新线程会执行相应 ...

  8. DAY17-Django之model增删改

    添加表记录 普通字段 #方式1 publish_obj=Publish(name="人民出版社",city="北京",email="renMin@16 ...

  9. form表单提交target属性使用

    通过form表单提交刷新iframe <form action="doctor/selPackage" target="projectlistframe" ...

  10. TCP/IP 笔记 1.1 概 述

    四个层次 每一层负责不同的功能:1) 链路层,有时也称作数据链路层或网络接口层,通常包括操作系统中的设备驱动程序和计算机中对应的网络接口卡.它们一起处理与电缆(或其他任何传输媒介)的物理接口细节.2) ...