Pagini recente » Cod sursa (job #911549) | Cod sursa (job #2449409) | Cod sursa (job #1692435) | Cod sursa (job #361019) | Cod sursa (job #563942)
Cod sursa(job #563942)
#include <cstdio>
int main() {
int n, *fi, *prim, i, j;
long long rez = 0;
FILE *fin = fopen("fractii.in", "r");
FILE *fout = fopen("fractii.out", "w");
fscanf(fin,"%d",&n);
fi = new int[n+1];
prim = new int[n+1];
for(i=1;i<=n;i++) {
fi[i] = i;
prim[i] = 1;
}
for(i = 2;i<= n;i++) {
if(prim[i]) {
fi[i] = i-1;
for(j=i*2;j<=n;j+=i) {
prim[j] = 0;
fi[j] = (fi[j]/i)*(i-1);
}
}
}
for(i=1;i<=n;i++) {
rez += fi[i];
}
rez = 2*rez -1;
fprintf(fout, "%lld", rez);
return 0;
}