Cod sursa(job #370969)
Utilizator | Data | 2 decembrie 2009 20:57:57 | |
---|---|---|---|
Problema | Fractii | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.34 kb |
#include <stdio.h>
long phi[1000005];
int main(){
long long i,j,sum=0,n;
freopen("fractii.in","r",stdin);
freopen("fractii.out","w",stdout);
scanf("%lld",&n);
for(i=1;i<=n;i++){
phi[i]=i-1;}
for(i=2;i<=n;i++){
for(j=2*i;j<=n;j+=i){
phi[j]-=phi[i];
}
}
for(i=2;i<=n;i++){
sum+=phi[i];
}
printf("%lld\n",2*sum+1);
return 0;
}