Cod sursa(job #2178204)

Utilizator AvramDanielAvram Daniel AvramDaniel Data 19 martie 2018 11:28:57
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.54 kb
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define MOD 1999999973

ll a,b;

ll lgput(ll x, ll y){
    if (y == 1) return x%MOD;
    if (y & 1) return ((x%MOD) * lgput((x*x)%MOD, y/2))%MOD;
    else return lgput((x*x)%MOD, y/2)%MOD;
}
/*ll lgput(ll n,ll p){
if (p==1) return n;
if (p%2==0) return lgput((n*n)%MOD,p/2)%MOD;
else return (n*lgput((n*n)%MOD,p/2))%MOD;
}*/
int main(){
    ifstream cin ("lgput.in");
    ofstream cout ("lgput.out");
    cin >> a >> b;
    cout << lgput(a, b);
    return 0;
}