Cod sursa(job #361283)

Utilizator ScriamTertiuc Afanasie Scriam Data 4 noiembrie 2009 14:15:16
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator fpc Status done
Runda Arhiva educationala Marime 0.43 kb
Program ex;
var n,m,y,p : int64;
    f,g : text;




Function exp(x,n : int64) : int64;
begin
if n=0 then exp:=1 else
if n mod 2=0 then
begin
y:=exp(x,n div 2) mod m;
exp:=y*y mod m;
end
else
exp:=((x mod m)*exp(x,n-1) mod m) mod m;
end;




begin
assign(f,'lgput.in');   assign(g,'lgput.out');
reset(f);               rewrite(g);
readln(f,n,p);
m:=1999999973;
writeln(g,exp(n,p));
close(f);
close(g);
end.