Cod sursa(job #661774)

Utilizator sanzianaioneteIonete Sanziana sanzianaionete Data 15 ianuarie 2012 10:48:14
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.39 kb
#include<cstdio>
using namespace std;
int m=1999999973;
long long n,k=1,p,n1;
int main()
{
	freopen("lgput.in","r",stdin);
	freopen("lgput.out","w",stdout);
	scanf("%lld %lld\n",&n,&p);
	n=n%m;n1=n;
	while(p>1)
	{
		while(k<p)
		{
			n1=((n1%m)*(n1%m))%m;
			k=k*2;
		}
		p=p-k;
		k=1;
	}
	if(p==1) n1=(n1*n)%m;
	printf("%lld\n",n1);
	fclose(stdin);fclose(stdout);
	return 0;
}