欧拉函数(互质)

定义:

欧拉函数是指:一个数N,在1~N这个范围内,与N互质的数的“个数”记作 ϕ(N)
互质是指gcd(i,N) = 1
因为一个数总能被分解为:N = P1a1*P2a2*P3a3*....*Pkak
且欧拉函数为一个积性函数:ϕ(mn) = ϕ(m) * ϕ(n)

所以我们可以得到ϕ(N) = ϕ(P1a1)*ϕ(P2a2)*ϕ(P3a3)*......*ϕ(Pkak)
对于其中的某一项ϕ(Piai)分析:从1到Piai共有Piai个数,其中与Piai不互质的有Pi,2*Pi,3*Pi.....Piai1*Pi共有Piai1项,所以互质的就有Piai-Piai1项,所以我们可以得到公式

ϕ(N) = N * (1-1a1)*(1-1a2)*.....*(1-1ak)

代码实现:

  1. 朴素算法(公式法):
void solve() {
int x;
cin>>x;
int res = x;
for(int i = 2;i <= x/i;++i){
if(x%i == 0){
while(x%i == 0) x/= i;
res = res/i*(i-1);
}
}
if(x>1) res = res/x*(x-1);
cout<<res<<endl;
}

2.线性筛法

以上解释引用自Sundae

int primes[N],cnt;//线性筛
int phi[N];//欧拉函数
bool st[N];
void get_eulers(int n){
phi[1] = 1;
for(int i = 2;i <= n;++i){
if(!st[i]){
primes[cnt++] = i;
phi[i] = i-1;
}
for(int j = 0;primes[j]<=n/i;++j){
st[primes[j]*i] = true;
if(i%primes[j] == 0){
phi[primes[j]*i] = primes[j]*phi[i];
break;
}
phi[primes[j]*i] = phi[i]*(primes[j]-1);
}
}
}
posted @   empty_y  阅读(654)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示