#include"stdio.h"
#include"string.h"
#include"stdlib.h"
#define N 3000011
int phi[N];
void getphi()
{
int i,j;
phi[1]=1;
for(i=2;i<=3000000;i++) phi[i]=i;
for(i=2;i<=3000000;i++)
{
if(i==phi[i])
{
for(j=i;j<=3000000;j+=i)
{
phi[j]=phi[j]/i*(i-1);
}
}
}
}
int main()
{
int a,b;
int i;
__int64 ans;
getphi();
while(scanf("%d%d",&a,&b)!=-1)
{
ans=0;
for(i=a;i<=b;i++) ans+=phi[i];
printf("%I64d\n",ans);
}
return 0;
}
HDU 2824 欧拉函数 求小于等于n且与n互质数的个数
最新推荐文章于 2022-02-15 23:34:24 发布