Cod sursa(job #1255081)
Utilizator | Data | 4 noiembrie 2014 12:19:01 | |
---|---|---|---|
Problema | Fractii | Scor | 90 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.51 kb |
#include <iostream>
using namespace std;
long long N, S;
int main()
{
freopen ("fractii.in", "r", stdin);
freopen ("fractii.out", "w", stdout);
scanf ("%lld", &N);
long long NFractii[N];
for (int i=1; i<=N; ++i)
{
NFractii[i]=i;
S+=i;
}
for (int i=1; i<=N; ++i)
{
for (int j=2*i; j<=N; j+=i)
{
NFractii[j]-=NFractii[i];
S-=NFractii[i];
}
}
printf ("%lld\n", 2*S-1);
return 0;
}