Cod sursa(job #2028024)

Utilizator rangal3Tudor Anastasiei rangal3 Data 26 septembrie 2017 23:46:31
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.5 kb
#include <fstream>
#define in "lgput.in"
#define out "lgput.out"
#define mod 1999999973
using namespace std;

ifstream fin(in);
ofstream fout(out);

typedef unsigned long long ull;

inline ull ridlog(ull n,ull p)
{
    if(p == 1) return n;

    int R = ridlog(n,p/2);

    if(p%2 == 0)
    {
        return (R*R)%mod;
    }
    return (((R*R)%mod)*n)%mod;

}


int main()
{
    ull n,p;
    fin>>n>>p;
    fout<<ridlog(n,p);

    fin.close(); fout.close();
    return 0;
}