Cod sursa(job #2175427)

Utilizator UWantMyNameGheorghe Vlad Camil UWantMyName Data 16 martie 2018 17:07:43
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.53 kb
#include <bits/stdc++.h>
#define in "lgput.in"
#define out "lgput.out"
#define mod 1999999973
using namespace std;
ifstream fin(in);
ofstream fout(out);
typedef long long huge;

huge n,p;

huge lgput(huge baza, huge exp)
{
    if (exp == 1) return baza;
    else if (exp % 2 == 1) return baza * lgput(baza,exp - 1) % mod;
    else return lgput(baza,exp / 2) * lgput(baza, exp / 2) % mod;
}

int main()
{
    fin >> n >> p;
    fout << lgput(n,p) % mod << "\n";

    fin.close();
    fout.close();
    return 0;
}