poj 1811 随机素数和大数分解(模板)
Sample Input
2
5
10
Sample Output
Prime
2
模板学习:
判断是否是素数,数据很大,所以用miller,不是的话再用pollard rho分解
miller : 通过费马小定理,若N为素数,a^(N-1) = 1 (mod N),
再利用二次判定:
若x为素数,0<x<p, x*x = 1(mod q)
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cmath>
#include <time.h>
#define N 10100
typedef long long ll;
using namespace std; const int S = 8; //随机判定次数 一般8 - 10 // a*b%c
ll mult_mod(ll a,ll b,ll c)
{
a %= c;
b %= c;
ll ret = 0;
ll temp = a;
while(b)
{
if(b&1)
{
ret += temp;
if(ret > c) ret -= c;
}
temp <<= 1;
if(temp > c) temp -= c;
b >>= 1;
}
return ret; } // (a^n)%mod
ll pow_mod(ll a,ll n,ll mod)
{
ll ret = 1;
ll temp = a%mod;
while(n)
{
if(n & 1)
ret = mult_mod(ret,temp ,mod);
temp = mult_mod(temp,temp,mod);
n>>= 1;
}
return ret;
}
//通过费马小定理,a^(n-1)=1(mod n) ;来判断n是否是素数
bool check(ll a,ll n,ll x,ll t)
{
ll ret = pow_mod(a,x,n);
ll last = ret;
for(int i = 1; i <= t; i++)
{
ret = mult_mod(ret,ret,n); //二次探测
if(ret == 1 && last != 1 && last != n-1) return true;
last = ret;
}
if(ret != 1) return true;
else return false;
} bool miller_rabin(ll n) //随机素数
{
if(n < 2) return false;
if(n == 2) return true;
if((n&1) == 0) return false; //偶数
ll x = n - 1;
ll t = 0;
while((x&1) == 0)
{
x>>= 1;
t++;
};
srand(time(NULL)); //G++时不要 for(int i = 0; i < S; i++)
{
ll a = rand()%(n - 1) + 1;
if(check(a,n,x,t))
return false;
}
return true;
} ll factor[100];
int tol; ll gcd(ll a,ll b)
{
ll t;
while(b)
{
t = a;
a = b;
b = t % b;
}
if(a >= 0) return a;
else
return -a;
}
//找因子
ll pollard_rho(ll x,ll c)
{
ll i = 1,k = 2;
srand(time(NULL));
ll x1 = rand()%(x-1)+1;
ll y = x1;
while(1)
{
i++;
x1 = (mult_mod(x1,x1,x)+c)%x;
ll d = gcd(y-x1,x);
if(d!=1 && d!=x) return d;
if(y == x1) return x;
if(i == k)
{
y = x1;
k += k;
}
}
}
//对n进行分解,存入数组,
void findfac(ll n,int k) //大数分解
{
if(n == 1)
return ;
if(miller_rabin(n)) //判素
{
factor[tol++] = n;
return ;
}
ll p = n;
int c = k;
while( p>= n)
p = pollard_rho(p,c--); //防止死循环k,值变换
findfac(p,k);
findfac(n/p,k); } int main()
{
int t;
ll n;
scanf("%d",&t);
while(t--)
{
scanf("%I64d",&n);
if(miller_rabin(n)) printf("Prime\n");
else
{
tol = 0;
findfac(n,107);
ll ans = factor[0];
for(int i = 1; i < tol; i++)
ans = min(ans,factor[i]);
printf("%I64d\n",ans);
}
}
return 0;
}
poj 1811 随机素数和大数分解(模板)的更多相关文章
- POJ 1811 大素数判断
数据范围很大,用米勒罗宾测试和Pollard_Rho法可以分解大数. 模板在代码中 O.O #include <iostream> #include <cstdio> #inc ...
- Pollard_Rho大数分解模板题 pku-2191
题意:给你一个数n, 定义m=2k-1, {k|1<=k<=n},并且 k为素数; 当m为合数时,求分解为质因数,输出格式如下:47 * 178481 = 8388607 = ( ...
- POJ 1811 Prime Test 素性测试 分解素因子
题意: 给你一个数n(n <= 2^54),判断n是不是素数,如果是输出Prime,否则输出n最小的素因子 解题思路: 自然数素性测试可以看看Matrix67的 素数与素性测试 素因子分解利用 ...
- 数学#素数判定Miller_Rabin+大数因数分解Pollard_rho算法 POJ 1811&2429
素数判定Miller_Rabin算法详解: http://blog.csdn.net/maxichu/article/details/45458569 大数因数分解Pollard_rho算法详解: h ...
- poj 1811 Prime Test 大数素数测试+大数因子分解
Prime Test Time Limit: 6000MS Memory Limit: 65536K Total Submissions: 27129 Accepted: 6713 Case ...
- POJ 1811 Prime Test (Rabin-Miller强伪素数测试 和Pollard-rho 因数分解)
题目链接 Description Given a big integer number, you are required to find out whether it's a prime numbe ...
- poj 1811 Pallor Rho +Miller Rabin
/* 题目:给出一个数 如果是prime 输出prime 否则输出他的最小质因子 Miller Rabin +Poller Rho 大素数判定+大数找质因子 后面这个算法嘛 基于Birthday Pa ...
- 数学:随机素数测试(Miller_Rabin算法)和求整数素因子(Pollard_rho算法)
POJ1811 给一个大数,判断是否是素数,如果不是素数,打印出它的最小质因数 随机素数测试(Miller_Rabin算法) 求整数素因子(Pollard_rho算法) 科技题 #include< ...
- poj1181 大数分解
//Accepted 164 KB 422 ms //类似poj2429 大数分解 #include <cstdio> #include <cstring> #include ...
随机推荐
- 201621123043 《Java程序设计》第3周学习总结
1. 本周学习总结 初学面向对象,会学习到很多碎片化的概念与知识.尝试学会使用思维导图将这些碎片化的概念.知识点组织起来.请使用工具画出本周学习到的知识点及知识点之间的联系.步骤如下: 1.1 写出你 ...
- 用python实现简单购物车功能
all_asset = 0 i1 = input("请输入总资产:") all_asset = int(i1) goods = [ {'name':'电脑','price':199 ...
- sublime安装 和 插件安装
先从官网下载sublime https://www.sublimetext.com/3 安装完毕后 快捷键ctrl+` 或者View->Show Console,输入如下代码(sublime ...
- vue初尝试--组件
github代码同步网址 组件 (Component) 是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码.在较高层面上,组件是自定义元素,Vue.js 的编译器为它添 ...
- python之路--day13-模块
1,什么是模块 模块就是系统功能的集合体,在python中,一个py文件就是一个模块, 例如:module.py 其中module叫做模块名 2,使用模块 2.1 import导入模块 首次带入模块发 ...
- $.ajax 提交数据到后台.
//AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML -- (Extensible Markup Language 可扩展标记语言 ...
- JAVA_SE基础——2.环境变量的配置&测试JDK
哈喽,利用晚上的空余时间再写篇心的~~~ 谢谢大家 前一篇文章 JAVA_SE基础--JDK&JRE下载及安装http://blog.csdn.net/thescript_j/article ...
- Mysql编译安装详解
wget http://mirrors.cnnic.cn/apache/httpd/mysql-5.5.20.tar.gz root@Mysql-server ~]# yum install -y c ...
- 新概念英语(1-103)The French Test
Lesson 103 The French test 法语考试 Listen to the tape then answer this question. How long did the exam ...
- win10 如何让其他机器访问自己机器上的mysql
一.修改mysql 1.执行sql GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'Abc1234%' WITH GRANT OPTI ...