Cod sursa(job #2715775)

Utilizator 1chiriacOctavian Neculau 1chiriac Data 4 martie 2021 10:36:40
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.41 kb
#include <bits/stdc++.h>

using namespace std;
const long long MOD=1999999973;
long long n, p;
long long putere (long long a, long long b) {
	long long ans=1;
	for(int i=0;b>0;++i) {
		if(((1LL<<i) & b)!=0)
			ans=(ans*a)%MOD,b^=(1LL<<i);
		a=(a*a)%MOD;
	}
	return ans;
}
int main () {
	freopen("lgput.in","r",stdin);
	freopen("lgput.out","w",stdout);
	scanf("%lld%lld", &n, &p);
	printf("%lld", putere(n,p));
	return 0;
}