Mai intai trebuie sa te autentifici.
Cod sursa(job #1989969)
Utilizator | Data | 9 iunie 2017 19:07:16 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 10 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.53 kb |
#include <iostream>
#include <fstream>
#define MOD 1999999973
long long unsigned pow(long long nV, long long p) {
if (p == 0) return 1;
int aux = nV % MOD;
if (p == 1) return aux;
if (p % 2) return (aux * pow(aux * aux, (p - 1) / 2)) % MOD;
return pow(aux * aux, p / 2) % MOD;
}
int main() {
std::ifstream fileIn("lgput.in");
std::ofstream fileOut("lgput.out");
long long unsigned nV, p;
fileIn >> nV >> p;
fileOut << pow(nV, p) % MOD;
fileIn.close();
fileOut.close();
return 0;
}