题意:给一种深度欧拉函数,比如ϕ(13)=12,ϕ(12)=4,ϕ(4)=2,ϕ(2)=1,因为从13的欧拉函数到结果为1一共用了4步,所以depthphi[13]=4,现在让你求从m到n的depthnphi的和。
思路:这道题跟The Euler function这道题是连着的,思路差不多,先把2到200W的欧拉函数全求出来,然后再求2到200W的所有depthphi,然后从m加到n就行了。
#include <iostream>
using namespace std;
#define N 2000000
int phi[N+10],depth[N+10];
void Euler()
{
for(int i=1;i<=N;i++)
phi[i]=i;
for(int i=2;i<=N;i++)
{
if(phi[i]==i)
{
for(int j=i;j<=N;j+=i)
phi[j]-=phi[j]/i;
}
}
}
int getDepthn(int n)
{
if(n==1)
return 1;
return 1+getDepthn(phi[n]);
}
void depthnEuler()
{
for(int i=1;i<=N;i++)
depth[i]=getDepthn(phi[i]);
}
int main()
{
cin.sync_with_stdio(false);
int a,b,t;
Euler();
depthnEuler();
cin>>t;
while(t--)
{
while(cin>>a>>b)
{
long long sum=0;
for(int i=a;i<=b;i++)
sum+=depth[i];
cout<<sum<<"\n";
}
}
return 0;
}