P4718 [模板]Pollard-Rho算法
对一个大质数进行质因数分解 需要引用miller-robin来判素数
一直写的gcd居然挂掉了... 以后用__gcd了
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define ull unsigned long long
#define lb long double
ll maxfac; inline ll ksc(ull x,ull y,ll p){//O(1)快速乘(防爆long long)
return (x*y-(ull)((lb)x/p*y)*p+p)%p;
} ll pow_mod(ll x, ll y, ll mod) {
ll res = 1;
while(y) {
if(y & 1) res = ksc(res, x, mod);
x = ksc(x, x, mod);
y >>= 1;
}
return res;
} ll ABS(ll x) {
if(x < 0) return -x;
return x;
} inline bool mr(ll x,ll p){//mille rabin判质数
if(pow_mod(x, p-1, p) != 1) return false;//费马小定理
ll y = p - 1, z;
while(!(y & 1)){ //二次探测
y >>= 1;
z = pow_mod(x, y, p);
if(z != 1 && z != p - 1) return false;
if(z == p - 1) return true;
}
return true;
} inline bool isprime(ll x) {
if(x < 2) return false;//mille rabin判质数
if(x == 2 || x == 3 || x == 5 || x==7 || x == 43) return true;
return mr(2, x) && mr(3, x) && mr(5, x) && mr(7, x) && mr(43, x);
} inline ll rho(ll p){//求出p的非平凡因子
ll x, y, z, c, g; int i, j;//先摆出来(z用来存(y-x)的乘积)
while(1){//保证一定求出一个因子来
y = x = rand() % p;//随机初始化
z = 1; c = rand() % p;//初始化
i = 0, j = 1;//倍增初始化
while(++i){//开始玄学生成
x = (ksc(x, x, p) + c) % p;//可能要用快速乘
z = ksc(z, ABS(y - x), p);//我们将每一次的(y-x)都累乘起来
if(x == y || !z) break;//如果跑完了环就再换一组试试(注意当z=0时,继续下去是没意义的)
if(!(i % 127) || i == j){//我们不仅在等127次之后gcd我们还会倍增的来gcd
g = __gcd(z, p);
if(g > 1) return g;
if(i == j) y = x ,j <<= 1;//维护倍增正确性,并判环(一箭双雕)
}
}
}
} inline void prho(ll p) {
if(p <= maxfac) return;
if(isprime(p)) {
maxfac = p;
return;
}
ll pi = rho(p);//我们一次必定能求的出一个因子,所以不用while
while(p % pi == 0) p /= pi;//记得要除尽
prho(pi); prho(p);
} int main() {
int T;
scanf("%d", &T);
srand(time(0));
while(T--) {
//srand(time(0));
ll x;
scanf("%lld", &x);
maxfac = 1;
if(isprime(x)) puts("Prime");
else {
prho(x);
printf("%lld\n", maxfac);
}
}
return 0;
}
P4718 [模板]Pollard-Rho算法的更多相关文章
- Pollard Rho算法浅谈
Pollard Rho介绍 Pollard Rho算法是Pollard[1]在1975年[2]发明的一种将大整数因数分解的算法 其中Pollard来源于发明者Pollard的姓,Rho则来自内部伪随机 ...
- Pollard Rho 算法简介
\(\text{update 2019.8.18}\) 由于本人将大部分精力花在了cnblogs上,而不是洛谷博客,评论区提出的一些问题直到今天才解决. 下面给出的Pollard Rho函数已给出散点 ...
- Miller Rabin素数检测与Pollard Rho算法
一些前置知识可以看一下我的联赛前数学知识 如何判断一个数是否为质数 方法一:试除法 扫描\(2\sim \sqrt{n}\)之间的所有整数,依次检查它们能否整除\(n\),若都不能整除,则\(n\)是 ...
- Pollard rho算法+Miller Rabin算法 BZOJ 3668 Rabin-Miller算法
BZOJ 3667: Rabin-Miller算法 Time Limit: 60 Sec Memory Limit: 512 MBSubmit: 1044 Solved: 322[Submit][ ...
- 初学Pollard Rho算法
前言 \(Pollard\ Rho\)是一个著名的大数质因数分解算法,它的实现基于一个神奇的算法:\(MillerRabin\)素数测试(关于\(MillerRabin\),可以参考这篇博客:初学Mi ...
- 大整数分解质因数(Pollard rho算法)
#include <iostream> #include <cstring> #include <cstdlib> #include <stdio.h> ...
- BZOJ 5330 Luogu P4607 [SDOI2018]反回文串 (莫比乌斯反演、Pollard Rho算法)
题目链接 (BZOJ) https://www.lydsy.com/JudgeOnline/problem.php?id=5330 (Luogu) https://www.luogu.org/prob ...
- 【快速因数分解】Pollard's Rho 算法
Pollard-Rho 是一个很神奇的算法,用于在 $O(n^{\frac{1}4}) $的期望时间复杂度内计算合数 n 的某个非平凡因子(除了1和它本身以外能整除它的数).事书上给出的复杂度是 \( ...
- Miller-Rabin 素性测试 与 Pollard Rho 大整数分解
\(\\\) Miller-Rabin 素性测试 考虑如何检验一个数字是否为素数. 经典的试除法复杂度 \(O(\sqrt N)\) 适用于询问 \(N\le 10^{16}\) 的时候. 如果我们要 ...
- Pollard Rho因子分解算法
有一类问题,要求我们将一个正整数x,分解为两个非平凡因子(平凡因子为1与x)的乘积x=ab. 显然我们需要先检测x是否为素数(如果是素数将无解),可以使用Miller-Rabin算法来进行测试. Po ...
随机推荐
- 晋升新一线的合肥,跨平台的.NET氛围究竟如何?
大伙可能不知道,2020年合肥已经成功晋升为新一线城市了.本文通过对目前合肥.NET招聘信息以及公众号的相关数据的分析来看下目前合肥.NET的大环境.就着2020中国.NET开发者峰会的顺利举行的东风 ...
- docker搭建前端环境
开发环境的搭建,是新人入职后的第一道槛,有时一个小小的问题就能阻塞半天.如果能提供一个工具在短时间内搞定开发环境,势必提高新人对团队的印象分!docker就是这样一个工具. 镜像&容器 doc ...
- 计算机考研复试真题 N阶楼梯上楼问题
题目描述 N阶楼梯上楼问题:一次可以走两阶或一阶,问有多少种上楼方式.(要求采用非递归) 输入描述: 输入包括一个整数N,(1<=N<90). 输出描述: 可能有多组测试数据,对于每组数据 ...
- JVM-Class文件的结构
Class类文件的结构 Class文件是一株以8个字节为单位的二进制流.各个数据项目严格按照顺序紧凑的排列在文件之中,中间没有任何的分隔符,当遇到占用的空间大于8个字节时,会按照高位在前的方式进行分割 ...
- wpf 在不同DPI下如何在DrawingVisual中画出清晰的图形
环境Win10 VS2017 .Net Framework4.7.1 本文仅讨论在DrawingVisual中进行的画图. WPF单位,系统DPI,显示器DPI三者的定义及关系 WPF单位:一 ...
- Java 安全之Weblogic 2018-2628&2018-2893分析
Java 安全之Weblogic 2018-2628&2018-2893分析 0x00 前言 续上一个weblogic T3协议的反序列化漏洞接着分析该补丁的绕过方式,根据weblogic的补 ...
- 【Linux】fstab中 每个字段代表的含义
默认情况下,fstab中已经有了当前的分区配置,内容可能类似: # <file system> <mount point> <type> <options ...
- LeetCode1022. 从根到叶的二进制数之和
题目 class Solution { public: int ans = 0; int sumRootToLeaf(TreeNode* root) { dfs(root,0); return ans ...
- Ubuntu下修改缺省dash shell为bash shell
Debian和Ubuntu下缺省使用的是shell是dash,而不是bash.从/bin/sh软连接的指向可以看出这点. 这是一个不同于bash的shell,它主要是为了执行脚本而出现,而不是交互,它 ...
- STGAN: A Unified Selective Transfer Network for Arbitrary Image Attribute Editing 阅读笔记和pytorch代码解读
一.论文采用的新方法 1.AttGan中skip connect的局限性 由于encoder中对特征的下采样实际上可能损失部分特征,我们在decoder中进行上采样和转置卷积也无法恢复所有特征,因此A ...