Cod sursa(job #416420)

Utilizator warcryAlin B warcry Data 12 martie 2010 18:42:41
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.32 kb
#include<stdio.h>
#include<string.h>
int main()
{
    freopen("lgput.in","r",stdin);
	freopen("lgput.out","w",stdout);
    int n,p,i;
    long long m= 1999999973,sol=1,a;
	scanf("%d %d",&n,&p);
	a=n;
	for (i=0;(1<<i)<=p;++i)
	{
		if(((1<<i)&p)>0)
			sol= (sol*a)%m;
		a=(a*a)%m;
	}
	printf("%lld\n", sol);
}