POJ1811

给一个大数,判断是否是素数,如果不是素数,打印出它的最小质因数

随机素数测试(Miller_Rabin算法)

求整数素因子(Pollard_rho算法)

科技题

 #include<cstdlib>
#include<cstdio>
const int maxn=;
const int S=;
int tot;
long long n;
long long factor[maxn];
long long muti_mod(long long a,long long b,long long c)
{
//(a*b) mod c a,b,c<2^63
a%=c;
b%=c;
long long ret=;
while(b)
{
if(b&)
{
ret+=a;
if(ret>=c) ret-=c;
}
a<<=;
if(a>=c) a-=c;
b>>=;
}
return ret;
}
long long pow_mod(long long x,long long n,long long mod)
{
//x^n mod c
if(n==) return x%mod;
int bit[],k=;
while(n)
{
bit[k++]=n&;
n>>=;
}
long long ret=;
for(k=k-;k>=;k--)
{
ret=muti_mod(ret,ret,mod);
if(bit[k]==) ret=muti_mod(ret,x,mod);
}
return ret;
}
bool check(long long a,long long n,long long x,long long t)
{
long long ret=pow_mod(a,x,n),last=ret;
for(int i=;i<=t;i++)
{
ret=muti_mod(ret,ret,n);
if(ret==&&last!=&&last!=n-) return ;
last=ret;
}
if(ret!=) return ;
return ;
}
bool Miller_Rabin(long long n)
{
long long x=n-,t=;
while((x&)==) x>>=,t++;
bool flag=;
if(t>=&&(x&)==)
{
for(int k=;k<S;k++)
{
long long a=rand()%(n-)+;
if(check(a,n,x,t)) {flag=;break;}
flag=;
}
}
if(flag==||n==) return ;
return ;
}
long long gcd(long long a,long long b)
{
if(a==) return ;
if(a<) return gcd(-a,b);
while(b)
{
long long t=a%b;a=b;b=t;
}
return a;
}
long long Pollard_rho(long long x,long long c)
{
long long i=,x0=rand()%x,y=x0,k=;
while()
{
i++;
x0=(muti_mod(x0,x0,x)+c)%x;
long long d=gcd(y-x0,x);
if(d!=&&d!=x) return d;
if(y==x0) return x;
if(i==k)
{
y=x0;
k+=k;
}
}
}
void findfac(long long n) //递归分解质因数
{
if(!Miller_Rabin(n))
{
factor[tot++]=n;
return;
}
long long p=n;
while(p>=n) p=Pollard_rho(p,rand()%(n-)+);
findfac(p);
findfac(n/p);
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
scanf("%I64d",&n);
if(!Miller_Rabin(n))
{
printf("Prime\n");
continue;
}
tot=;
findfac(n);
long long ans=factor[];
for(int i=;i<tot;i++)
if(factor[i]<ans) ans=factor[i];
printf("%I64d\n",ans);
}
return ;
}

数学:随机素数测试(Miller_Rabin算法)和求整数素因子(Pollard_rho算法)的更多相关文章

  1. HDU2138 随机素数测试 Miller-Rabin算法

    题目描述 Give you a lot of positive integers, just to find out how many prime numbers there are.. In eac ...

  2. POJ1811_Prime Test【Miller Rabin素数测试】【Pollar Rho整数分解】

    Prime Test Time Limit: 6000MS Memory Limit: 65536K Total Submissions: 29193 Accepted: 7392 Case Time ...

  3. HDU1164_Eddy&#39;s research I【Miller Rabin素数测试】【Pollar Rho整数分解】

    Eddy's research I Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others ...

  4. 数论 - Miller_Rabin素数测试 + pollard_rho算法分解质因数 ---- poj 1811 : Prime Test

    Prime Test Time Limit: 6000MS   Memory Limit: 65536K Total Submissions: 29046   Accepted: 7342 Case ...

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

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

  6. Miller_Rabin 素数测试

    费马定理的逆定理几乎可以用来判断一个数是否为素数,但是有一些数是判断不出来的,因此,Miller_Rabin测试方法对费马的测试过程做了改进,克服其存在的问题. 推理过程如下(摘自维基百科): 摘自另 ...

  7. Miller-Rabin素数测试算法(POJ1811Prime Test)

    题目链接:http://poj.org/problem?id=1811 题目解析:2<=n<2^54,如果n是素数直接输出,否则求N的最小质因数. 求大整数最小质因数的算法没看懂,不打算看 ...

  8. Miller-Rabin素数测试算法

    用来干嘛的 ​   要判断一个数 \(n\) 是否为素数,最朴素直接的办法是以\(O(\sqrt n)\) 时间复杂度地从2到 \(\sqrt n\) 循环即可得到最准确的结果.但是如果在 \(n\) ...

  9. Miller-Rabbin随机性素数测试算法

    //**************************************************************** // Miller_Rabin 算法进行素数测试 //速度快,而且 ...

随机推荐

  1. 20162328蔡文琛 Bag类

    在刚刚开始着手这个作业时,想的是使用for循环来自己写出add等方法来,但是在看过API后知道了Arraylist这个java已有的列表类,于是就只用ArrayList的方法很快的就做了出来.在进行B ...

  2. C#高级编程 (第六版) 学习 第六章:运算符和类型强制转换

    第六章 运算符和类型强制转换 1,运算符 类别 运算符 算术运算符 + - * / % 逻辑运算符 & | ^ ~ && || ! 字符串连接运算符 + 增量和减量运算符 ++ ...

  3. 复利计算C语言转java的相关代码

    static void principal()// 计算本金 { int N, m; double i, F, P; System.out.printf("复利终值:"); F = ...

  4. 对Excle的行和列进行检查 单元格类型转换代码 ;

    对Excle的行和列进行检查  转换代码 : ** * 导入信息 */ @Override public List<Object> add(HttpServletRequest reque ...

  5. 设计模式PHP篇(三)————装饰器模式

    简单的用php实现了装饰器模式: <?php /** *简单的装饰器模式 */ class PrintText { protected $decorators = []; public func ...

  6. 【转】MySQL数据类型

    1.整型 MySQL数据类型 含义(有符号) tinyint(m) 1个字节  范围(-128~127) smallint(m) 2个字节  范围(-32768~32767) mediumint(m) ...

  7. 【C++】new和delete表达式与内存管理

    new和delete表达式可以用来动态创建和释放单个对象,也可以用来动态创建和释放动态数组. 定义变量时,必须指定其数据类型和名字.而动态创建对象时,只需指定其数据类型,而不必为该对象命名.new表达 ...

  8. ZOJ3466-The Hive II

    题意 有一个六边形格子,共 \(n\) 行,每行有 8 个位置,有一些格子不能走.求用一些环覆盖所有可走格子的方案数.\(n\le 10\) . 分析 插头dp,只不过是六边形上的,分奇数列和偶数列讨 ...

  9. C++解析(27):数组、智能指针与单例类模板

    0.目录 1.数组类模板 1.1 类模板高效率求和 1.2 数组类模板 1.3 堆数组类模板 2.智能指针类模板 2.1 使用智能指针 2.2 智能指针类模板 3.单例类模板 3.1 实现单例模式 3 ...

  10. ubuntu成功安装搜狗输入法

    在安装之前,我们要先了解一个事实,那就是linux下安装软件和Windows是非常不同的,并不是简单地双击安装包就可以安装了.linux很多软件都有自己的一个依赖源,如果不先安装好这些依赖源,你是无法 ...