Cod sursa(job #1588674)
Utilizator | Data | 3 februarie 2016 14:32:00 | |
---|---|---|---|
Problema | Fractii | Scor | 30 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.45 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("fractii.in");
ofstream out("fractii.out");
int ndv[1000001];
int main()
{
int n;
in>>n;
for(int i=2;i<=n;i++)
ndv[i]=i-1;
for(int i=2;i<=n;i++)
{
for(int j=2*i;j<=n;j+=i)
ndv[j]-=ndv[i];
}
int cnt=0;
for(int i=2;i<=n;i++)
{
cnt+=ndv[i];
}
cnt=cnt*2+1;
out<<cnt;
return 0;
}