Cod sursa(job #222767)

Utilizator SheepBOYFelix Liviu SheepBOY Data 25 noiembrie 2008 08:51:12
Problema Sum Scor 70
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.4 kb
#include<stdio.h>
#define lim 100000
int n,x,fi[100002];
void init()
{
	int i,j;
	for(i=1;i<=lim;i++)
		fi[i]=i;
	for(i=2;i<=lim;i++)
		if(fi[i]==i)
			for(j=i;j<=lim;j+=i)
				fi[j]=fi[j]/i*(i-1);
}
int main()
{
    freopen("sum.in","r",stdin);
	freopen("sum.out","w",stdout);
	scanf("%d",&n);
	init();
	while(n)
	{
		scanf("%d",&x);
		printf("%d\n",(x<<1)*fi[x]);
		n--;
	}
	return 0;
}