Pagini recente » Cod sursa (job #1886829) | Cod sursa (job #365935) | Cod sursa (job #55408) | Cod sursa (job #2172558) | Cod sursa (job #1152416)
#include <iostream>
#include <fstream>
#include <string.h>
#define mm 1999999973
using namespace std;
ifstream fin("lgput.in");
ofstream fout("lgput.out");
unsigned long long int n,p;
unsigned long long int ex(unsigned long long int x,unsigned long long int n)
{
if(n<0)
return ex(1/x,-n);
else
{
if(n==0)
return 1;
else
{
if(n==1)
return x;
else
{
if(n%2==0)
{
if(x*x>=mm)
return ex((x*x)%mm, n/2);
else
return ex(x*x, n/2);
}
else
{
if(n%2==1)
{
if(x*x>=mm)
return x*ex((x*x)%mm, (n-1)/2);
else
return x*ex(x*x, (n-1)/2);
}
}
}
}
}
return 0;
}
int main()
{
fin>>n>>p;
fout<<ex(n,p)%mm;
return 0;
}