【模板】筛欧拉函数
埃氏筛
复杂度:\(O(nlogn)\)
go(i,1,n)ou[i]=i;
go(i,2,n){
if(ou[i]==i)
for(int j=i;j<=n;j+=i) ou[j]=ou[j]/i*(i-1);
}
线性筛
复杂度:\(O(n)\)
phi[1]=1;
go(i,2,n){
if(!vis[i]){
p[++tot]=i;
ou[i]=i-1;
}
for(int j=1;j<=tot&&p[j]*i<=n;++j){
vis[p[j]*i]=1;
if(i%p[j]==0){
ou[p[j]*i]=ou[i]*p[j];
break;
}
else ou[p[j]*i]=ou[i]*(p[j]-1);
}
}