Pagini recente » Monitorul de evaluare | Cod sursa (job #3190395) | Cod sursa (job #3173553) | Cod sursa (job #2771853) | Cod sursa (job #2464964)
#include<iostream>
#include<fstream>
const unsigned long long MODULO = 1999999973;
unsigned long long pow(unsigned long long x, unsigned long long e) {
unsigned long long xx = 1;
for (int i = 0; (1 << i) <= e; ++i) {
if ((1 << i) & e) {
xx = (x * xx) % MODULO;
}
x = (x * x) % MODULO;
}
return x;
}
int main() {
std::ifstream in("lgput.in");
std::ofstream out("lgput.out");
unsigned long long n, p;
in >> n >> p;
out << pow(n % MODULO, p);
return 0;
}