Cod sursa(job #388804)
Utilizator | Data | 30 ianuarie 2010 23:21:11 | |
---|---|---|---|
Problema | Fractii | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.42 kb |
#include <fstream>
using namespace std;
#define MAX 1000005
FILE *f=fopen("fractii.in","r");
FILE *g=fopen("fractii.out","w");
long v[MAX];
int main()
{
long long n,i,j,nr=0;
fscanf(f,"%lld",&n);
for (i=1;i<=n;i++)
v[i]=i;
for (i=2;i<=n;i++){
if (v[i]==i)
for (j=i;j<=n;j+=i)
v[j] /=i, v[j] *= (i-1);
nr+=v[i];}
fprintf(g,"%lld",nr*2+1);
fclose(f);
fclose(g);
return 0;
}