Cod sursa(job #2022308)

Utilizator AsttridMocanu Ada Astrid Asttrid Data 16 septembrie 2017 12:09:33
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.42 kb
#include<bits/stdc++.h>
using namespace std;
const long long prim=1999999973;
ifstream in("lgput.in");
ofstream out("lgput.out");
long long n,p;
long long put(long long x,long long n)
{if(x<=1)return x;
else if(n==0)return 1;
else if(n==1)return x;
else if(n%2==0)return put((x*x)%prim,n/2);
else return x*put((x*x)%prim,(n-1)/2);
}

int main(){
in>>n>>p;
out<<put(n,p);
in.close();
out.close();
return 0;}