Cod sursa(job #2989588)

Utilizator cincadavidCinca David Andrei cincadavid Data 6 martie 2023 20:06:03
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.57 kb
#include <fstream>
#include <vector>
#include <algorithm>
#include <math.h>

using namespace std;

ifstream cin("lgput.in");
ofstream cout("lgput.out");

const int mod=1999999973;

int LogP(int a,int b)
{
    if(b==0)
    {
        return 1;
    }
    if(b==1)
    {
        return a%mod;
    }
    if(b%2==1)
    {
        return a*LogP((long long int)(a*a)%mod,b/2)%mod;
    }
    else
    {
        return LogP((long long int)(a*a)%mod,b/2)%mod;
    }
}

int main()
{
    long long int a,b;
    cin>>a>>b;
    cout<<LogP(a,b);

    return 0;
}