Pagini recente » Cod sursa (job #216867) | Cod sursa (job #774964) | Cod sursa (job #532483) | Monitorul de evaluare | Cod sursa (job #1984568)
#include <bits/stdc++.h>
#define TROLL 1999999973
using namespace std;
int exp_by_squaring(int n, int p)
{
if(p==0)
return 1;
else if(p==1)
return n;
else if(n%2==0)
return exp_by_squaring(n*n, p/2)%TROLL;
else if(n%2==1)
return n*exp_by_squaring(n*n, (p-1)/2)&TROLL;
}
int main()
{
freopen("lgput.in", "r", stdin);
freopen("lgput.out", "w", stdout);
int n, p;
scanf("%d%d", &n, &p);
printf("%d\n", exp_by_squaring(n, p));
return 0;
}