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 ...
随机推荐
- Count PAT's (25) PAT甲级真题
题目分析: 由于本题字符串长度有10^5所以直接暴力是不可取的,猜测最后的算法应该是先预处理一下再走一层循环就能得到答案,所以本题的关键就在于这个预处理的过程,由于本题字符串匹配的内容的固定的PAT, ...
- Docker haproxy应用构建 (五)
编写dockerfile from centos-base:v1 MAINTAINER 57674891@qq.com RUN mkdir -p /data/{soft,src,logs,script ...
- MySQL常用字符串函数和日期函数
数据函数 SELECT ABS(-8); /*绝对值*/ SELECT CEILING(9.4); /*向上取整*/ SELECT FLOOR(9.4); /*向下取整*/ SELECT RAND() ...
- kubernets之服务重定向
一 服务的强大功能之处的其他表现 前面介绍的所有有关服务的说明,都是将集群内部的pod应用暴露出来提供外部客户端或者内部的客户端进行访问,但是服务的强大之处远远不止于此 服务甚至可以将集群外部的应用 ...
- 彻底解决小程序无法触发SESSION问题
一.首先找到第一次发起网络请求的地址,将服务器返回set-cookie当全局变量存储起来 wx.request({ ...... success: function(res) { console.lo ...
- 拒演"拼命工作"的苦情戏,如何更聪明地提高工作效率?
前几天PDD的事情又把互联网打工人的工作状态推向了大众视野,引起了大家的口诛笔伐.但是目前来看这种愤慨终究是暂时的,作用甚微.在大环境短时间无法改变的前提下,想想如何应对,或许比在网上愤愤不平破口大骂 ...
- python_mmdt:从0到1--实现简单恶意代码分类器(二)
概述 上篇文章python_mmdt:一种基于敏感哈希生成特征向量的python库(一)我们介绍了一种叫mmdt_hash(敏感哈希)生成方法,并对其中的概念做了基本介绍.本篇,我们重点谈谈mmdt_ ...
- 从零搭建一个IdentityServer——项目搭建
本篇文章是基于ASP.NET CORE 5.0以及IdentityServer4的IdentityServer搭建,为什么要从零搭建呢?IdentityServer4本身就有很多模板可以直接生成一个可 ...
- (10)-Python3之--引入
1.什么是模块 .py文件就是模块 模块名有命名要求: 1.不要以数字.下划线开头.特殊符号.也不要以中文开头. 2.通常来说,都是以字母开头. 3.不要以关键字来命名.内置函数.内置模块.不要以第三 ...
- MySQL高可用HA——keepalived配置
0. Keepalived介绍 Keepalived是基于VRRP(Virtual Router Redundancy Protocol,虚拟路由器冗余协议)协议的一款高可用软件.Keepaili ...