Cod sursa(job #2044566)

Utilizator razvanradulescuRadulescu Razvan razvanradulescu Data 21 octombrie 2017 11:05:23
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.51 kb
#include <iostream>
#include <fstream>
#define MOD 1999999973
using namespace std;

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

void put(long long int a, long long int p, long long int &rez)
{
    if(p == 0)
        return;
    if(p % 2 != 0)
    {
        rez *= a % MOD;
        p--;
    }
    else
    {
        p /= 2;
        a = a*a % MOD;
    }
    put(a,p,rez);
}

int main()
{
    long long int a, p ,rez = 1;
    f>>a>>p;
    put(a, p ,rez);
    g<<rez%MOD;
    return 0;
}