Cod sursa(job #154145)

Utilizator oumbraPaul Filimoon oumbra Data 10 martie 2008 22:28:50
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.48 kb
#include <cstdio>

#define MOD 1999999973

long long pp(long long n, long long p)
{
	long long c;

	if(p == 0)
		return 1;

	if (p % 2)
	{
		c = pp(n, p/2);
		c %= MOD;
		c *= c;
		c %= MOD;
		c *= n;
		c %= MOD;
		return c;	
	}
	else
	{
		c = pp(n, p/2);
		c %= MOD;
		c *= c;
		c %= MOD;
		return c;
	}
}

int main()
{
	freopen("lgput.in", "r", stdin);
	freopen("lgput.out", "w", stdout);

	long long n, p;

	scanf("%lld%lld", &n, &p);
	printf("%lld\n", pp(n, p) % MOD);

	return 0;
}