Cod sursa(job #152159)
Utilizator | Data | 9 martie 2008 09:22:06 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.39 kb |
#include<iostream>
#include<stdio.h>
FILE *f,*g;
int main ()
{
long n,p;
long rez=1;
f=fopen("igput.in","r");
g=fopen("igput.out","w");
fscanf(f,"%ld %ld",&n,&p);
fclose(f);
while(p)
{
if(p&1)
{
if(rez>=1999999973)
rez=(rez*n)%1999999973;
else
rez=rez*n;
p=p-1;
}
n=n*n;
p=p/2;
}
fprintf(g,"%ld",rez);
fclose(g);
return 0;
}