Cod sursa(job #2062092)

Utilizator berindeiChesa Matei berindei Data 9 noiembrie 2017 23:19:47
Problema Ridicare la putere in timp logaritmic Scor 80
Compilator cpp Status done
Runda Arhiva educationala Marime 0.38 kb
#include <bits/stdc++.h>
#define MOD 1999999973
using namespace std;
ifstream in("lgput.in");
ofstream out("lgput.out");
long long put(long long n, long long p){
    if (p==0) return 1;
    if (p==1) return n;
    if (p%2==0) return put(n*n%MOD, p/2)%MOD;
    return n*(put(n*n%MOD, (p-1)/2)%MOD);
}
int main(){
    long long n, p;
    in >> n >> p;
    out << put(n, p);
}