Cod sursa(job #3295518)

Utilizator mcrg05Craciunescu Mihnea Gabriel mcrg05 Data 6 mai 2025 12:36:08
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.44 kb
#include<bits/stdc++.h>
#define MOD 1999999973

using namespace std;

uint64_t lgput(uint64_t n, uint64_t p){ //n la p
    n = n % MOD;
    if (p == 0) return 1;
    else if (p & 1) return n * lgput(n * n, (p - 1) / 2);
    else return lgput(n * n, p / 2);
}

int main(){
    freopen("lgput.in", "r", stdin);
    freopen("lgput.out", "w", stdout);
    uint64_t n, p;
    cin >> n >> p;
    cout << lgput(n, p) % MOD;
    return 0;
}