Pagini recente » Monitorul de evaluare | Istoria paginii utilizator/bardaliviu | Istoria paginii utilizator/spiridon_gabriela | Monitorul de evaluare | Cod sursa (job #2333740)
#include <bits/stdc++.h>
using namespace std;
ifstream f("fractii.in");
ofstream g("fractii.out");
const int NMAX=1e6+5;
int N;
int Euler[NMAX];
inline void Indicator (int N)
{
for(int i=2; i<=N; ++i)
Euler[i]=i-1;
for(int i=2; i<=N; ++i)
for(int j=2*i; j<=N; j+=i)
Euler[j]-=Euler[i];
}
long long ans=0;
int main()
{
f.tie(NULL);
f>>N;
Indicator(N);
ans=1;
for(int i=1; i<=N; ++i)
ans+=1LL*Euler[i];
ans=ans*1LL*2;
--ans;
g<<ans<<'\n';
return 0;
}