Cod sursa(job #971193)

Utilizator cosmo0093Raduta Cosmin cosmo0093 Data 8 iulie 2013 18:27:27
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.41 kb
#include <fstream>

long long lgput(long long unsigned n, long long p)
{
	if(p < 0) return lgput(1 / n, -p);
	if(p == 1) return n;
	if(p == 0) return 1;
	if(p % 2 == 0) return lgput(n * n, p / 2);
	return lgput(n * n, (p - 1) / 2);
}

int main(void)
{
	std::ifstream in("lgput.in");
	std::ofstream out("lgput.out");
	long long nV, nP;
	in >> nV >> nP;
	out << lgput(nV, nP) % 1999999973;
	return 0;
}