Pagini recente » Cod sursa (job #1766384) | Istoria paginii runda/rar9/clasament | Cod sursa (job #775938) | Cod sursa (job #2358827) | Cod sursa (job #237447)
Cod sursa(job #237447)
/*Raspundeti la N intrebari de tipul: care este suma numerelor Y prime cu un numar X,
si care respecta proprietatea 0 < Y < 2*X.
Date de intrare
Prima linie a fisierului de intrare sum.in contine un numar intreg N.
Pe urmatoarele N linii se afla cate un numar X.
Date de iesire
*/
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <iostream>
#include <cstdlib>
#include<fstream>
#define dim 200000
using namespace std;
ifstream f("sum.in");
ofstream g("sum.out");
void fi(long long n, long long *v)
{
/* functia lui euler cu ciurul lui Eratostene
http://infoarena.ro/forum/index.php?topic=2512.0
v[i] = nr intregilor pozitivi <i si primi cu i
*/
long long i,j;
for( i=1;i <= n;i++) v[i]=i-1;
for( i=2;i <= n;i++)
for(j=i+i;j<=n;j=j+i)
v[j]=v[j]-v[i];
}
int main()
{
long long n,x, *v,i,s=0;
v = new long long [dim];
f>>n;
fi(dim,v);
for(i=1;i<=n;i++)
{
f>>x;
g<<2*x*v[x]<<'\n';
}
delete v;
f.close();
g.close();
return EXIT_SUCCESS;
}