Cod sursa(job #1400024)

Utilizator teo.serbanescuTeo Serbanescu teo.serbanescu Data 25 martie 2015 02:22:24
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.41 kb
#include <fstream>

using namespace std;

fstream f("lgput.in", ios::in);
fstream g("lgput.out", ios::out);

const unsigned long long m = 1999999973;
unsigned int long long n, p, a, i, sol;

int main()
{
    f >> n >> p;
    a = n;
    sol = 1;
    for (i = 0; (1 << i) <= p; ++i)
    {
        if (((1 << i) & p) > 0) sol = (sol * a) % m;
        a = (a * a) % m;
    }
    g << sol;
    return 0;
}