Cod sursa(job #1093580)

Utilizator SeekHunt1334Septimiu Bodica SeekHunt1334 Data 28 ianuarie 2014 11:56:28
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.56 kb
#include <iostream>
#include <fstream>
using namespace std;

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

long long n, p, sol = 1;
const int modulo = 1999999973;

int main()
{
    fin >> n >> p;

    for (int i = 0; (1<<i) <= p; ++i) // parcurge bitii
    {
        if ( (1 << i) & p )         // daca ambii biti sunt 1
            sol = (sol * n) % modulo; // solutia se inmulteste cu n
        n = ( n * n ) % modulo;    // n ridicat la patrat
    }

    fout << sol << '\n';

    fin.close();
    fout.close();
    return 0;
}