Cod sursa(job #2387925)

Utilizator moltComan Calin molt Data 25 martie 2019 14:12:15
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.55 kb
#include <bits/stdc++.h>

using namespace std;

ifstream in("lgput.in");
ofstream out("lgput.out");

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

long long ridicare_putere(long long baza, long long exp)
{
    long long rez = 1;
    while (exp > 0)
        if (exp % 2 == 0)
            {exp /= 2;
            baza *= baza;
            baza %= MOD;
            }
        else
            {--exp;
            rez *= baza;
            rez %= MOD;
            }
    return rez % MOD;
}

int main()
{
    in>>n>>p;
    out<<ridicare_putere(n,p) % MOD;
    return 0;
}