对一个大质数进行质因数分解 需要引用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算法的更多相关文章

  1. Pollard Rho算法浅谈

    Pollard Rho介绍 Pollard Rho算法是Pollard[1]在1975年[2]发明的一种将大整数因数分解的算法 其中Pollard来源于发明者Pollard的姓,Rho则来自内部伪随机 ...

  2. Pollard Rho 算法简介

    \(\text{update 2019.8.18}\) 由于本人将大部分精力花在了cnblogs上,而不是洛谷博客,评论区提出的一些问题直到今天才解决. 下面给出的Pollard Rho函数已给出散点 ...

  3. Miller Rabin素数检测与Pollard Rho算法

    一些前置知识可以看一下我的联赛前数学知识 如何判断一个数是否为质数 方法一:试除法 扫描\(2\sim \sqrt{n}\)之间的所有整数,依次检查它们能否整除\(n\),若都不能整除,则\(n\)是 ...

  4. Pollard rho算法+Miller Rabin算法 BZOJ 3668 Rabin-Miller算法

    BZOJ 3667: Rabin-Miller算法 Time Limit: 60 Sec  Memory Limit: 512 MBSubmit: 1044  Solved: 322[Submit][ ...

  5. 初学Pollard Rho算法

    前言 \(Pollard\ Rho\)是一个著名的大数质因数分解算法,它的实现基于一个神奇的算法:\(MillerRabin\)素数测试(关于\(MillerRabin\),可以参考这篇博客:初学Mi ...

  6. 大整数分解质因数(Pollard rho算法)

    #include <iostream> #include <cstring> #include <cstdlib> #include <stdio.h> ...

  7. BZOJ 5330 Luogu P4607 [SDOI2018]反回文串 (莫比乌斯反演、Pollard Rho算法)

    题目链接 (BZOJ) https://www.lydsy.com/JudgeOnline/problem.php?id=5330 (Luogu) https://www.luogu.org/prob ...

  8. 【快速因数分解】Pollard's Rho 算法

    Pollard-Rho 是一个很神奇的算法,用于在 $O(n^{\frac{1}4}) $的期望时间复杂度内计算合数 n 的某个非平凡因子(除了1和它本身以外能整除它的数).事书上给出的复杂度是 \( ...

  9. Miller-Rabin 素性测试 与 Pollard Rho 大整数分解

    \(\\\) Miller-Rabin 素性测试 考虑如何检验一个数字是否为素数. 经典的试除法复杂度 \(O(\sqrt N)\) 适用于询问 \(N\le 10^{16}\) 的时候. 如果我们要 ...

  10. Pollard Rho因子分解算法

    有一类问题,要求我们将一个正整数x,分解为两个非平凡因子(平凡因子为1与x)的乘积x=ab. 显然我们需要先检测x是否为素数(如果是素数将无解),可以使用Miller-Rabin算法来进行测试. Po ...

随机推荐

  1. 数组的方法some和includes

    some() 方法用于检测数组中的元素是否满足指定条件(函数提供). some() 方法会依次执行数组的每个元素: 如果有一个元素满足条件,则表达式返回true , 剩余的元素不会再执行检测. 如果没 ...

  2. Token验证的流程及如何准确的判断一个数据的类型

    Token验证的流程: 1,客户端使用用户名跟密码请求登录:2,服务端收到请求,去验证用户名与密码:3,验证成功后,服务端会签发一个 Token,再把这个 Token 发送给客户端:4,客户端收到 T ...

  3. (二)数据源处理4-excel部分封装及数据转换

    excel02.py # -*- coding: utf-8 -*-#@File :excel_oper_02.py#@Auth : wwd#@Time : 2020/12/7 8:16 下午impo ...

  4. LeetCode700. 二叉搜索树中的搜索

    题目 简单递归 1 class Solution { 2 public: 3 TreeNode* searchBST(TreeNode* root, int val) { 4 if(!root) re ...

  5. C语言逗号运算符(C语言学习笔记)

    什么是逗号运算符 逗号运算符 逗号运算符是指在C语言中,多个表达式可以用逗号分开,其中用逗号分开的表达式的值分别结算,但整个表达式的值是最后一个表达式的值. 用法 多个变量赋值 原因:"=& ...

  6. 前端知识(二)03-Webpack-谷粒学院

    目录 一.什么是Webpack 二.Webpack安装 1.全局安装 2.安装后查看版本号 三.创建项目 1.初始化项目 2.创建src文件夹 3.src下创建common.js 4.src下创建ut ...

  7. Python小度

    这只是一个对话器!还不能听歌(反正我也没在UNIT平台配置听歌的功能)! 反正最近也不知怎么的,就想做一个AI对话器语音识别和语音输出都不要,input()和print()就行本来准备用小爱的,但要实 ...

  8. 抛弃 .NET 经典错误:object null reference , 使用安全扩展方法? 希望对大家有帮助---Bitter.Frame 引用类型的安全转换

    还是一样,我不喜欢长篇大论,除非关乎我设计思想领域的文章.大家过来看,都是想节省时间,能用白话表达的内容,绝不长篇大论.能直接上核心代码的,绝不上混淆代码. 长期从事 .NET 工作的人都知道..NE ...

  9. C++ 无法打开 源 文件 "ntddk.h"

    原因是SDK版本太高了,或者版本不对应WDK,换一个SDK版本就好了.

  10. no-referrer-when-downgrade

    原因: 从一个网站链接到另外一个网站会产生新的http请求,referrer是http请求中表示来源的字段.no-referrer-when-downgrade表示从https协议降为http协议时不 ...