Pagini recente » Cod sursa (job #1672432) | Cod sursa (job #892293) | Cod sursa (job #1434123) | Cod sursa (job #2339515) | Cod sursa (job #2373860)
#include <fstream>
using namespace std;
ifstream f("fractii.in");
ofstream g("fractii.out");
int v[1000001],k,n,nr,x,sol;
bool cr[1000001];
void ciur()
{
int i,j;
cr[1]==1;
cr[0]==1;
for (i=2;i*i<=n;i++)
if (cr[i]==0) for (j=2;j*i<=n;j++) cr[i*j]=1;
for (i=2;i<=n;i++) if (cr[i]==0) v[++k]=i;
}
int main()
{
int i,j;
f>>n;
ciur();
for (i=2;i<=n;i++)
{
nr=i;
x=i;
j=1;
while (v[j]*v[j]<=x && x>1)
{
if (x%v[j]==0)
{
while (x%v[j]==0) x/=v[j];
nr=nr*(v[j]-1)/v[j];
}
j++;
}
if (x>1) nr=nr*(x-1)/x;
sol+=2*nr;
}
g<<sol+1;
return 0;
}