Cod sursa(job #333068)
Utilizator | Data | 21 iulie 2009 13:52:50 | |
---|---|---|---|
Problema | Fractii | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.44 kb |
#include<stdio.h>
#include<stdlib.h>
void main()
{
long n,i,j,*x;
double s=0;
FILE *f,*g;
f=fopen("fractii.in","r");
g=fopen("fractii.out","w");
fscanf(f,"%ld",&n);
x=(long*)malloc(1+n*sizeof(long));
for(i=1;i<=n;i++)x[i]=i;
for(i=2;i<=n;i++)
if(x[i]==i)
for(j=i;j<=n;j+=i){x[j]/=i;x[j]*=(i-1);}
for(i=2;i<=n;i++)s+=x[i];
s*=2;s++;
fprintf(g,"%.0lf",s);
fclose(f);fclose(g);
return 0;
}