Pagini recente » Cod sursa (job #1941135) | Cod sursa (job #2524822) | Cod sursa (job #509188) | Cod sursa (job #2359278) | Cod sursa (job #935096)
Cod sursa(job #935096)
#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 = 0, p = 1;
while (p <= pw) {
if (p & pw) {
res += n;
res %= 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;
}