Cod sursa(job #2118687)

Utilizator CozehNita Horia Teodor Cozeh Data 30 ianuarie 2018 21:10:47
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.45 kb
#include <fstream>
using namespace std;

ifstream fin("lgput.in");
ofstream fout("lgput.out");

long long int pow(long long int x, long long int n)
{
    if(n < 0) return pow(1/x, -n);
    else if(n == 0) return 1;
    else if(n == 1) return x;
    else if(n%2 == 0) return pow(x*x%1999999973, n/2);
    else if(n%2 == 1) return x * pow(x*x%1999999973, (n-1)/2);
}

int main()
{
    long long int n,x;
    fin>>x>>n;
    fout<<pow(x,n);
}