Cod sursa(job #2252083)
Utilizator | Data | 2 octombrie 2018 12:05:03 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 100 |
Compilator | cpp | Status | done |
Runda | musai_must | Marime | 0.46 kb |
#include <iostream>
#include <fstream>
#define M 1999999973
std::ifstream in("lgput.in");
std::ofstream out("lgput.out");
using namespace std;
long long n,m;
long long lgput(long long n, long long p)
{
long long sol=1;
for(long long i=1;i<(1<<30);i=(i<<1))
{
if(p&i)
{
sol=(sol*n)%M;
}
n=(n*n)%M;
}
return sol;
}
int main()
{
in>>n>>m;
out<<lgput(n,m);
return 0;
}