Pagini recente » Cod sursa (job #2382942) | Cod sursa (job #412066) | Cod sursa (job #1000743) | Cod sursa (job #1608170) | Cod sursa (job #1881858)
#include <iostream>
#include <cstdio>
using namespace std;
long long primicuel[1000001];
int v[1000001];
int main()
{
freopen("sum.in", "rt", stdin);
freopen("sum.out", "wt", stdout);
int i,n,m=0,j;
scanf("%d", &n);
for(i=1;i<=n;i++)
{
scanf("%d", &v[i]);
m=max(v[i],m);
}
for(i=1;i<=m;i++)
primicuel[i]=i;
for(i=2;i<=m;i++)
{
if(primicuel[i]==i)
for(j=i;j<=m;j+=i)
{
primicuel[j]/=i;
primicuel[j]*=(i-1);
}
}
for(i=1;i<=n;i++)
{
printf("%lld\n", v[i]*2*primicuel[v[i]]);
}
return 0;
}