Cod sursa(job #2355175)
Utilizator | Data | 25 februarie 2019 21:20:55 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.5 kb |
#include <iostream>
#include <cstdio>
#define MOD 1999999973
using namespace std;
long long p,n,q=1;
int log()
{
while(p)
{
if(p%2==0)
{
n=(n*n)%MOD;
p/=2;
}
else{
q=(q*n)%MOD;
p--;
}
}
q=q%MOD;
printf("%lld",q);
}
int main()
{
freopen("lgput.in","r",stdin);
freopen("lgput.out","w",stdout);
scanf("%lld %lld",&n,&p);
log();
return 0;
}