Cod sursa(job #448514)

Utilizator HoriaClementHoriaC HoriaClement Data 3 mai 2010 21:37:45
Problema Sum Scor 45
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.43 kb
#include <cstdio>

int phi[1<<17],n,x;

void multiplu(long long N)
{
	for (int i=1;i<=N;i++) 
		phi[i]=i;
	for (int i=2;i<=N;i++)
		if (phi[i]==i)
			for (int j=i;j<=N;j+=i) phi[j] /=i, phi[j] *= (i-1);
}
void rez()
{
	freopen("sum.in","r",stdin);
	freopen("sum.out","w",stdout);
	scanf("%d",&n);
	for(int k=1;k<=n;++k)
	{
		scanf("%d",&x);
		multiplu(x);
		printf("%d",phi[x]*x*2);
		printf("\n");
	}
}
int main()
{
	rez();
	return 0;
}