Cod sursa(job #189992)

Utilizator radu_voroneanuVoroneanu Radu Stefan radu_voroneanu Data 19 mai 2008 16:52:18
Problema Sum Scor 70
Compilator fpc Status done
Runda Arhiva de probleme Marime 0.53 kb
var phi:array[1..200000] of longint;
    f,g:text;
    i,n,j,x:longint;
begin
 assign(f,'sum.in'); reset(f);
 assign(g,'sum.out'); rewrite(g);
 n:=200000;
 for i:=2 to n do
  phi[i]:=i;
 j:=2;
 while (j<=n) do begin
  phi[j]:=phi[j] shr 1;
  j:=j+2;
 end;
 for i:=3 to n do
  if phi[i]=i then begin
   j:=i;
   while (j<=n) do begin
    phi[j]:=phi[j]-(phi[j] div i);
    j:=j+i;
   end;
  end;
 phi[1]:=0;
 read(f,n);
 for i:=1 to n do begin
  read(f,x);
  writeln(g,x*phi[x] shl 1);
 end;
 close(f); close(g);
end.