Cod sursa(job #1576343)

Utilizator loo_k01Luca Silviu Catalin loo_k01 Data 22 ianuarie 2016 12:14:14
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.46 kb
#include <fstream>

using namespace std;

int main()
{
    int p, a, prod, n;
    ifstream fin ("lgput.in");
    ofstream fout ("lgput.out");

    p = 1999999973;
    prod = 1;
    fin >> a >> n;

    while(n>0)
    {
        if(n%2 == 1)
        {
            prod = 1LL*prod * a % p;
            n--;
        }
        n = n/2;
        a = 1LL * a*a % p;
    }
    fout << prod << "\n";
    fin.close();
    fout.close();
    return 0;
}