题目链接: 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. LINUX必须记住的指令

    写在前面: 1,<你一定要知道的关于Linux文件目录操作的12个常用命令>是楼主收集的关于Linux文件目录操作最常用的命令,包括文件或目录的新建.拷贝.移动.删除.查看等,是开发人员操 ...

  2. mybatis sql中的条件语句

    1.mybatis判断是否为空或null <if test="type!=null and type!=''"> AND type = #{type} </if& ...

  3. 西安电子科技大学第16届程序设计竞赛 F Operating System (unique() 去重函数)

    链接:https://www.nowcoder.com/acm/contest/107/F来源:牛客网 Operating System 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ ...

  4. 用python的for循环写冒泡排序

    题目:利用for循环,完成a=[1,7,4,89,34,2]的冒泡排序(冒泡排序:小的排前面,大的排后面.) 第一种:可以看到每次排序的结果 a = [100,97,4,89,34,2] n = 0 ...

  5. idea右键单击没有 svn选项处理办法

    问题一: IntelliJ IDEA打开带SVN信息的项目不显示SVN信息,项目右键SVN以及图标还有Changes都不显示解决方法 在VCS菜单中有个开关,叫Enabled Version Cont ...

  6. Rails、Nginx、Passenger、bundle之间的协作关系

    引自:http://www.zhihu.com/question/20062163 Bundle是Gem包的依赖管理工具,RubyGem本身有依赖管理为何还要Bundle呢?有时候两个gem虽然都依赖 ...

  7. PowerDesigner的Additional Checkes 中使用统配符

    在Domian或字段的的约束条件中,会用的正则表达式等约束.但正则表达式 regexp_like(ICAO,'^([A-Z]{4}$')中要出现明确字段名如ICAO,每个使用同样约束的字段都要修改此字 ...

  8. Oracle Management Packs

    http://kerryosborne.oracle-guy.com/2008/10/oracle-management-packs/ There has been quite a bit of co ...

  9. 我积累的Java实用代码

    1.解压zip文件 /** * 解压输入的zip流,Java默认的解压只能处理UTF-8编码的文件或者目录名,否则会报MALFORMED异常 * * @param is 输入流 * @param ou ...

  10. 在异步回调中调用MessageBox.Show

    public static void Test() { ThreadStart aThreadStart = delegate() { ); MessageBox.Show("Good!&q ...