Cod sursa(job #2323613)

Utilizator alexbota2oooAlexandru Bota alexbota2ooo Data 19 ianuarie 2019 13:54:56
Problema Ridicare la putere in timp logaritmic Scor 30
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.57 kb
///Exponentiere in timp logaritmic
#include <fstream>
#define MOD 1999999973
using namespace std;

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

long long a, b;

long long Ridicare(long long a, long long b)
{
    if (b == 1)
        return a % 1999999973;
    if (b % 2 == 1)
        return a * ((Ridicare(a, b / 2) % MOD) * (Ridicare(a, b / 2) % 1999999973)) % MOD;
    else
        return ((Ridicare(a, b / 2) % 1999999973) * (Ridicare(a, b / 2) % 1999999973)) % 1999999973;
}

int main()
{
    fin >> a >> b;
    fout << Ridicare(a, b);
}