求gcd(x,y)=p等价于求gcd(x/p,y/p)=1,转化为了n/p内互质的个数
所以欧拉函数,因为有序所以乘2,再特判一下只有在1,1情况下才会重复计算,所以每次都减一
数组开小一时爽,提交wa火葬场!!!
#include<iostream> #include<cstdio> #include<cstring> using namespace std; const int maxn=10000009; int n; int ck[maxn],prime[maxn],phi[maxn],tot; long long sum[maxn]; void eular(int n){ phi[1]=1; for(int i=2;i<=n;i++){ if(!ck[i]){ ck[i]=i,prime[++tot]=i; phi[i]=i-1; } for(int j=1;j<=tot;j++){ if(prime[j]>ck[i] || i*prime[j]>n)break; ck[prime[j]*i]=prime[j]; phi[i*prime[j]]=phi[i]*(i%prime[j]?prime[j]-1:prime[j]); } } } int main(){ scanf("%d",&n); eular(n); for(int i=1;i<=n;i++)sum[i]=sum[i-1]+phi[i]; long long ans=0; for(int i=1;i<=tot;i++){ ans+=2*sum[n/prime[i]]-1; } printf("%lld\n",ans); }
原文:https://www.cnblogs.com/superminivan/p/10864805.html