Cod sursa(job #1563798)

Utilizator vladbatalanBatalan Vlad vladbatalan Data 6 ianuarie 2016 18:52:07
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.53 kb
#include <iostream>
#include <fstream>
#define p 1999999973
using namespace std;
int a,b;
ifstream fin("lgput.in");
ofstream fout("lgput.out");

long long int Ridicare_la_putere(long long int x,long long int n)
{
    if(n==0)return 1;
    else if(n==1) return x%p;
    else if(n%2==0) return Ridicare_la_putere((x*x)%p,n/2)%p;
    else return ((x%p)*(Ridicare_la_putere((x*x)%p,(n-1)/2)%p))%p;
}
int main()
{
    long long int a, putere;
    fin>>a>>putere;
    fout<<Ridicare_la_putere(a,putere)%p;
    return 0;
}