Cod sursa(job #2074658)

Utilizator lonca.sorin01Lonca Sorin lonca.sorin01 Data 24 noiembrie 2017 21:02:34
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.55 kb
#include <iostream>
#include <fstream>

using namespace std;

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

int lgput(int a, int b)
{
    if (b % 2 == 1)
    {
        return (a % 1999999973)*lgput(a % 1999999973, (b - 1) % 1999999973);
    }
    if (b == 0)
    {
        return 1 % 1999999973;
    }
    if (b == 1)
    {
        return a % 1999999973;
    }
    return lgput((a % 1999999973) * (a % 1999999973), (b / 2) % 1999999973);
}

int main()
{
    int a, b;
    f>>a>>b;
    g<<lgput(a, b) % 1999999973;
    return 0;
}