Cod sursa(job #1344438)

Utilizator tudorv96Tudor Varan tudorv96 Data 16 februarie 2015 18:50:46
Problema Ridicare la putere in timp logaritmic Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.42 kb
#include <fstream>
using namespace std;

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

const unsigned mod = 1999999973;

unsigned a, b, sol = 1, tmp = 1;

int main() {
    fin >> a >> b;
    b %= (mod - 1);
    tmp = a;
    for (unsigned i = 1; i <= 31 && (1 << i) <= b; i++) {
        if ((1 << i) & b)
            sol = (sol * tmp) % mod;
        tmp = (tmp * tmp) % mod;
    }
    fout << sol;
}