Cod sursa(job #2020906)
Utilizator | Data | 12 septembrie 2017 09:18:06 | |
---|---|---|---|
Problema | Fractii | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.43 kb |
#include <cstdio>
using namespace std;
int phi[1000005];
int main()
{
freopen("fractii.in","r",stdin);
freopen("fractii.out","w",stdout);
long long sum=1;
int n;
scanf("%d",&n);
for (int i = 2; i<=n; i++)
phi[i] = i-1;
for (int i = 2; i<=n; i++)
{
sum+=2LL*phi[i];
for (int j = i+i; j<=n; j+=i)
phi[j]-=phi[i];
}
printf("%llu",sum);
}