Pagini recente » Cod sursa (job #1887532) | Cod sursa (job #2472825) | Istoria paginii runda/trainingts_bf/clasament | Cod sursa (job #1209909) | Cod sursa (job #1312151)
#include <stdio.h>
FILE *fin, *fout;
int main()
{
fin = fopen("fractii.in", "r");
fout = fopen("fractii.out", "w");
int n;
fscanf(fin, "%d", &n);
long long int sieve[n], sum = 0;
for(int i = 1; i<= n; i++) sieve[i] = i-1;
for(int i = 2; i<= n; i++)
{
for(int j = 2*i; j<= n; j+=i)
{
sieve[j] -= sieve[i];
}
sum+= sieve[i];
}
fprintf(fout, "%lld\n", sum * 2 + 1);
fclose(fin);
fclose(fout);
return 0;
}