Cod sursa(job #1851157)

Utilizator alexkolumeRadulescu Ioan-Alexandru alexkolume Data 19 ianuarie 2017 13:59:23
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.55 kb
#include <fstream>
#include <iostream>

using namespace std;

long long modulo(long long n)
{
    n %= 1999999973;
    return n;
}

long long exponentiere(long long n, long long p)
{
    if(p == 1)
        return n;
    if(p % 2 == 1)
        return modulo(n * exponentiere(n, p-1));
    else
        return modulo(exponentiere(modulo(n*n), p/2));
}

int main()
{
    long long n, p, k;

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

    fin >> n >> p;

    n = exponentiere(n, p);

    fout << n;
    return 0;
}