Pagini recente » Cod sursa (job #1201163) | Cod sursa (job #2823051) | Cod sursa (job #2027717) | Cod sursa (job #927175) | Cod sursa (job #935120)
Cod sursa(job #935120)
#include <fstream>
#include <math.h>
#define M 1999999973
using namespace std;
// basic log pw;
int lgpow(int n, int pw)
{
if (pw == 0)
return 1;
int res = 0, p = 1;
while (p <= pw) {
if (p & pw)
res += n;
n = n * n;
p = p * 2;
}
return res;
}unsigned long long lgpow_mod_m(unsigned long long n, unsigned long long pw, unsigned long long m)
{
unsigned long long res = 1, p = 1;
while (p <= pw) {
if (p & pw)
res = res * n % m;
n = n * n % m;
p <<= 1;
}
return res;
}
int main()
{
ifstream in("lgput.in");
ofstream out("lgput.out");
unsigned long long n, p;
in>>n>>p;
//out<<lgpow(n, p)<<endl;
out<<lgpow_mod_m(n, p, M)<<endl;
return 0;
}