Pagini recente » Cod sursa (job #1401119) | Cod sursa (job #2540890) | Cod sursa (job #15197) | Cod sursa (job #1290070) | Cod sursa (job #935093)
Cod sursa(job #935093)
#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;
}
int lgpow_mod_m(long long n, long long pw, int m)
{
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");
int n, p;
in>>n>>p;
//out<<lgpow(n, p)<<endl;
out<<lgpow_mod_m(n, p, M)<<endl;
return 0;
}