Cod sursa(job #2847040)

Utilizator vladutzu_finutzuVlad Cacenschi vladutzu_finutzu Data 10 februarie 2022 08:11:23
Problema Ridicare la putere in timp logaritmic Scor 30
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.53 kb
#include <fstream>
using namespace std;
ifstream cin("lgput.in");
ofstream cout("lgput.out");
long long n, p;
const long long MOD = 1999999973;
long long logPow(long long n, long long p)
{
    if(p == 0)
        return 1;
    
    if(p % 2 == 0)
    {
        long long k = logPow(n, p/2);
        return ((k % MOD) * (k % MOD)) % MOD;
    }
    
    long long k = logPow(n, (p-1) / 2);
    return ((n % MOD) * (k % MOD) * (k % MOD)) % MOD;
}
int main(int argc, const char * argv[]) {
    cin>>n>>p;
    
    cout<<logPow(n, p);
    return 0;
}