Cod sursa(job #2535422)

Utilizator nTropicManescu Bogdan Constantin nTropic Data 31 ianuarie 2020 20:52:32
Problema Ridicare la putere in timp logaritmic Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.49 kb
#include <bits/stdc++.h>

using namespace std;

const int mod = 1999999973;
long long n, p;

long long lgpow(int n, int p) {
    int sol = 1;
    while (n) {
        if (p & 1)
            sol = n * p % mod;
        p >>= 1;
        n *= n;
    }
    return sol;
}

int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);

    freopen("lgput.in", "r", stdin);
    freopen("lgput.out", "w", stdout);

    cin >> n >> p;
    cout << lgpow(n, p);
}