Cod sursa(job #2673150)
Utilizator | Data | 15 noiembrie 2020 21:59:12 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.42 kb |
#include <fstream>
const int mod = 1999999973;
int prod(int a, int b) { return (1LL * a * b) % mod; }
int putlog(int n, int k) {
if (k == 0) return 1;
int x = putlog(n, k / 2);
if (k % 2 == 0) return prod(x, x);
return prod(prod(x, x), n);
}
int main() {
std::ifstream fin("lgput.in");
std::ofstream fout("lgput.out");
int n, k;
fin >> n >> k;
fout << putlog(n, k);
}