Cod sursa(job #2493484)

Utilizator sorana5Gligor Sorana sorana5 Data 16 noiembrie 2019 13:02:17
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.61 kb
#include <iostream>
#include <fstream>

using namespace std;

ifstream f("lgput.in");
ofstream g("lgput.out");

int main()
{
    long long n, p, r, R, i = 0, a;
    f>>n>>p;
    R = 1999999973;
    ///(1<<i) = 2 ^i;
    a = n;
    r = 1;
    while ((1<<i) <= p)
    {
        if (((1<<i)&p) != 0)
            r = (r * a) % R;
        a = (a * a) % R;
        i++;
    }
    g<<r;
    /*while (p > 0)
    {
       n = n * n;
       p = p - 1;
    }
    n = n % r;
    cout<<n;
    */

    /*while (n / 2 > 0)
    {
        s = s * 10 + n % 2;
    }
    cout<<s;
    */
    return 0;
}