Cod sursa(job #2091049)

Utilizator valorosu_300Cristian Gherman valorosu_300 Data 19 decembrie 2017 08:24:50
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.49 kb
#include <fstream>
using namespace std;
ifstream in("lgput.in");
ofstream out("lgput.out");
const int MOD = 1999999973;
int main()
{
    long long int n,p,cop, sol = 1, v[33];
    in>>n>>p;
    in.close();
    cop = n;
    v[0] = 1;
    for(int i=1;i<=32;i++)
        v[i] = v[i - 1] * 2;
    for(unsigned int i=0;v[i]<=p;++i){
        if((v[i]&p) > 0)
            sol = (sol * cop) % MOD;
        cop = (cop * cop) % MOD;
    }
    out<<sol<<"\n";
    out.close();
    return 0;
}