Cod sursa(job #402908)
Utilizator | Data | 24 februarie 2010 11:57:33 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 10 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.35 kb |
#include<stdio.h>
#define mod 1999999973
long long int n,m,t=1;
int main()
{
freopen("lgput.in","r",stdin);
freopen("lgput.out","w",stdout);
scanf("%lld %lld",&n,&m);
while(m)
{
if(m%2==0)
{
n*=n;
m/=2;
}
else
{
if(m==1)break;
m--;
m/=2;
n*=n;
}
n%=mod;
}
printf("%lld",n);
return 0;
}