Cod sursa(job #1834456)

Utilizator mdiannnaMarusic Diana mdiannna Data 24 decembrie 2016 17:15:14
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.52 kb
#include <iostream>
#include <cstdint>
#include <cmath>

using namespace std;

int64_t exponentiere(int N, int P){
    int64_t rez;
    if(P == 0)
        return 1;
    if(P == 1)
        return N;
    if(P%2 == 0)
        return (exponentiere(N*N, P/2)) % 1999999973 ;
    else
        return (N*(exponentiere(N*N, (P-1)/2))) % 1999999973 ;
}

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

    int N, P;
    cin >> N >> P;
    cout << exponentiere(N, P) % 1999999973;
    return 0;
}