Cod sursa(job #1613061)
| Utilizator | Data | 25 februarie 2016 10:36:28 | |
|---|---|---|---|
| Problema | Fractii | Scor | 30 |
| Compilator | c | Status | done |
| Runda | Arhiva de probleme | Marime | 0.48 kb |
#include <stdio.h>
#include <stdlib.h>
int e[1000000];
void calcul(int n){
int p,j,i;
p=1;
for(i=2;i<=n;i++)
e[i]=i;
for(i=2;i<=n;i++)
if(e[i]==i)
for(j=i;j<=n;j+=i)
e[j]=e[j]/i*(i-1);
}
int main()
{
freopen("fractii.in","r",stdin);
freopen("fractii.out","w",stdout);
int n,s=1,i;
scanf("%d",&n);
calcul(n);
for(i=2;i<=n;i++)
s+=2*e[i];
printf("%d",s);
return 0;
}
