Cod sursa(job #1649459)

Utilizator adu18sptAndrei Mircea adu18spt Data 11 martie 2016 13:44:01
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.44 kb
#include<fstream>
using namespace std;
ifstream fin("lgput.in");
ofstream fout("lgput.out");
unsigned long n,p,rez;
const long long MOD=1999999973;

unsigned long put(unsigned long a,unsigned long b)
{
	unsigned r=1;
	
	while(b>1)
	{
		if(b%2==0)
		{
			b/=2;
			a=(a*a)%MOD;
			
		}
		else
		{
			r=(r*a)%MOD;
			b--;
		}
	}
	return (a*r)%MOD;
}

int main()
{
	fin>>n>>p;
	rez=put(n,p);
	fout<<rez;
	return 0;
}