bzoj 4802 欧拉函数 (pollardrho大数质因数分解)

bzoj4802

求\(10^{18}\)级别的数的欧拉函数。

pollardrho算法分解大数质因数即可。(主要是存模板)

#include <bits/stdc++.h>
using namespace std;

typedef long long ll;

ll sed=20170831,mo=LLONG_MAX,rt=1;
ll rand_() {
  rt=(((rt%sed)<<16)&mo);
  return rt;
}
ll range(int l,int r) {
  return rand_()%(r-l+1)+l;
}

ll gcd(ll a,ll b) {
  return b==0?a:gcd(b,a%b);
}

ll SlowMul(ll a,ll b,ll mo) {
  ll ret=0;
  while(b) {
    if(b&1) ret=(ret+a)%mo;
    a=(a+a)%mo;
    b>>=1;
  }
  return ret;
}

ll QuickPow(ll x,ll k,ll mo) {
  ll ret=1ll;
  while(k) {
    if(k&1) ret=SlowMul(ret,x,mo);
    x=SlowMul(x,x,mo);
    k>>=1;
  }
  return ret;
}

bool MillerRabin(ll x) {
  if(x==2) return true;
  int t=0;
  ll u=x-1;
  while(!(u&1)) {
    t++;
    u>>=1;
  }

  int s=20;
  ll now,pre;
  while(s--) {
    ll a=range(1,x-1);
    now=QuickPow(a,u,x);
    for(int z=0;z<t;z++) {
      pre=now;
      now=SlowMul(now,now,x);
      if(now==1 && pre!=1 && pre!=x-1) return false;
    }
    if(now!=1) return false;
  }
  return true;
}

ll PollardRho(ll n,int c) {
  ll x2=range(1,n-1),x1=x2,p,k=2;
  int tim=1;
  while(1) {
    tim++;
    x2=(SlowMul(x2,x2,n)+c)%n;
    p=gcd(n,(x1-x2+n)%n);
    if(p>1 && p<n) {
      return p;
    }
    if(x1==x2) return n;
    if(tim==k) {
      x1=x2;
      k<<=1;
    }
  }
}

vector<ll > prs;
void proce(ll x,int c) {
  if(x==1) return;
  if(MillerRabin(x)) {
    prs.push_back(x);
    return;
  }
  int p=x,tmp=c;
  while(p>=x) p=PollardRho(p,c--);
  proce(p,tmp);
  proce(x/p,tmp);
}

ll x;
int main() {
  scanf("%lld",&x);
  prs.clear();
  proce(x,7);
  sort(prs.begin(),prs.end());
  ll ans=x,pre=0;
  for(int i=0;i<(int)prs.size();i++) {
    if(prs[i]!=pre) ans=ans/prs[i]*(prs[i]-1),pre=prs[i];
  }
  printf("%lld\n",ans);
  return 0;
}

原文地址:https://www.cnblogs.com/darkroome/p/9218775.html

时间: 2024-10-12 12:58:44

bzoj 4802 欧拉函数 (pollardrho大数质因数分解)的相关文章

BZOJ 4802 欧拉函数

4802: 欧拉函数 Description 已知N,求phi(N) Input 正整数N.N<=10^18 Output 输出phi(N) Sample Input 8 Sample Output 4 很明显,这样的题就是一道十分简单的入门题.只是N比较大,但输入和输出都还没有爆long long.如果输入高精度数,那就很恶心了(虽然可以定义大整数类Big Int). phi[n]=n∏(1-(1/p)),所以是Miller-Rabin和Pollard-Rho算法,用来分解一个大数的质因子.

[bzoj 2818]欧拉函数

题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2818 枚举最大公约数,对于每一个质数p,只需要求出1<=x,y<=(n/p)范围内gcd(x,y)=1的对数,而这个对数就是类似欧拉函数的一个前缀和. #include<cstdio> #include<cstring> using namespace std; const int maxn=10000005; bool check[maxn]; int pri

BZOJ 4805: 欧拉函数求和

Description 求\(\sum_{i=1}^n\varphi(i),n\leqslant 2\times 10^9\) Solution 杜教筛... 见上篇... Code /************************************************************** Problem: 4805 User: BeiYu Language: C++ Result: Accepted Time:1100 ms Memory:48172 kb ********

POJ 2480 (约数+欧拉函数)

题目链接: http://poj.org/problem?id=2480 题目大意:求Σgcd(i,n). 解题思路: 如果i与n互质,gcd(i,n)=1,且总和=欧拉函数phi(n). 如果i与n不互质,那么只要枚举n的全部约数,对于一个约数d,必有gcd(i/d,n/d)互质,这部分的gcd和=d*欧拉函数phi(n/d). 不断累加暴力求解即可. 其实还可以公式化简,不过实在太繁琐了.可以参考金海峰神的解释. 由于要求好多欧拉函数,每次都分解质因数法必然TLE,这里所以采用O(√n)求单

bzoj4802 欧拉函数(附Millar-Rabin和Pollard-Rho讲解)

传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4802 [题解] 参考:http://www.matrix67.com/blog/archives/234 Millar-Rabin质数检验方法: 根据费马小定理,如果p是素数,a<p,那么有a^(p-1) mod p = 1. 直观想法我们直接取若干个a,如果都有一个不满足,那么p就是合数. 遗憾的是,存在Carmichael数:你无论取多少个a,有一个不满足,算我输. 比如:561 =

HDU 1695 GCD 欧拉函数+容斥原理+质因数分解

链接:http://acm.hdu.edu.cn/showproblem.php?pid=1695 题意:在[a,b]中的x,在[c,d]中的y,求x与y的最大公约数为k的组合有多少.(a=1, a <= b <= 100000, c=1, c <= d <= 100000, 0 <= k <= 100000) 思路:因为x与y的最大公约数为k,所以xx=x/k与yy=y/k一定互质.要从a/k和b/k之中选择互质的数,枚举1~b/k,当选择的yy小于等于a/k时,可以

bzoj 2186 [Sdoi2008]沙拉公主的困惑 欧拉函数

bzoj 2186 [Sdoi2008]沙拉公主的困惑 题意: 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为1到N的阶乘,但是,政府只发行编号与M!互质的钞票.房地产第一大户沙拉公主决定预测一下大富翁国现在所有真钞票的数量.现在,请你帮助沙拉公主解决这个问题,由于可能张数非常大,你只需计算出对R取模后的答案即可.R是一个质数. 限制: 数据组数T:1 <= T <= 10000 R <= 1e9+10 1 <= N,M <=10000000

BZOJ 3813 奇数国 欧拉函数+线段树+乘法逆元

题目大意:给出一个序列,支持修改操作,求这个序列连续一段的乘积的欧拉函数.每个数的最大质因子不超过281. 思路:φ(n) = n * (1 - 1 / p1) * (1 - 1 / p2) * (1 - 1 / p3) * (1 - 1 / p4)--*(1 - 1 / pn) = n  / (p1 * p2 * p3 * -- * pn) * ((p1 - 1) * (p2 - 1) * (p3 - 1) * -- * (pn - 1)) 于是这个东西只需要维护一下区间中的指数,用bitse

bzoj 2818 GCD 数论 欧拉函数

bzoj[2818]Gcd Description 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. Input 一个整数N Output 如题 Sample Input 4 Sample Output 4 HINT hint对于样例(2,2),(2,4),(3,3),(4,2) 1<=N<=10^7 题解一(自己yy) phi[i]表示与x互质的数的个数 即gcd(x,y)=1 1<=y<x ∴对于x,y 若a为素数 则gcd(xa,