Cod sursa(job #2190783)

Utilizator AndreiVisoiuAndrei Visoiu AndreiVisoiu Data 31 martie 2018 18:52:04
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.46 kb
#include <fstream>

using namespace std;

ifstream in("lgput.in");
ofstream out("lgput.out");
const int MOD = 1999999973;
int putere(long long x, long long p) {
    int a = 1;
    x %= MOD;
    while(p > 0) {
        while(p % 2 == 0) {
            x = x * x % MOD;
            p /= 2;
        }
        a = a * x % MOD;
        p--;
    }
    return a;
}

int main() {
    long long n, p;
    in >> n >> p;
    out << putere(n, p);
    return 0;
}