Cod sursa(job #2280351)
Utilizator | Data | 10 noiembrie 2018 14:55:13 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 0 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.5 kb |
#include <iostream>
#include <fstream>
#include <math.h>
using namespace std;
ifstream f ("lgput.in");
ofstream g ("lgput.out");
long long int k=1999999973;
long long int exp(long long int x,long long int y)
{
if(y==0)
{
return 1;
}
if(y%2)
{
return ((long long)x*(long long)(exp(x*x,(y-1)/2)));
}
return ((long long)exp(x*x,y/2));
}
int main()
{
long long int n,p;
f>>n>>p;
cout<<"Varianta mea: "<<(exp(n,p))%k<<endl;
return 0;
}