Cod sursa(job #2173778)

Utilizator dragosmdvMoldovan Dragos dragosmdv Data 16 martie 2018 00:49:44
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.51 kb
#include <iostream>
#include <fstream>

using namespace std;

ifstream fin("lgput.in");
ofstream fout("lgput.out");
int k= 1999999973;
int a, b;

long long put(long long a, long long b)
{
    long long rez=1;
    while(b!=1)
    {
        if(b%2==1)
        {
            rez=rez*a;
            rez%=k;
            b--;
        }
        a=a*a;
        a%=k;
        b/=2;
    }
    rez=rez*a;
    rez%=k;
    return rez;
}

int main()
{

    fin>>a>>b;
    fout<<put(a,b);
    return 0;
}