Cod sursa(job #1590335)

Utilizator dianaorasanuDiana Orasanu dianaorasanu Data 4 februarie 2016 21:57:07
Problema Ridicare la putere in timp logaritmic Scor 20
Compilator cpp Status done
Runda Arhiva educationala Marime 0.6 kb
#include <fstream>
//#include <iostream>

using namespace std;

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

long long putere(long long, long long);

long long a, b, c;

int main()
{
    fin >> a >> c;
    fout << putere(a, c);
    return 0;
}


long long putere(long long a, long long exp)
{
    if(exp == 1)
        return 2;
    else
    {
        b = putere(a, exp/2)%1999999973;
        if(exp%2 == 0)
            return (b%1999999973*(b%1999999973))%1999999973;
        else
            return ((((b%1999999973)*(b%1999999973))*(a%1999999973))%1999999973);
    }
}