Cod sursa(job #2414121)
| Utilizator | Data | 24 aprilie 2019 10:28:46 | |
|---|---|---|---|
| Problema | Ridicare la putere in timp logaritmic | Scor | 0 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.45 kb |
#include <iostream>
#include <fstream>
using namespace std;
const int MOD = 1999999973;
int ridicare_logaritmica(int N, int P) {
int r = 1;
while (N) {
if (P % 2 == 1)
r = r * N;
N *= N;
P /= 2;
}
return r;
}
int main(){
unsigned N, P;
ifstream f("lgput.in");
ofstream g("lgput.out");
f >> N >> P;
cout << ridicare_logaritmica(N, P) % MOD;
return 0;
}
