Cod sursa(job #1538921)
| Utilizator | Data | 29 noiembrie 2015 23:58:44 | |
|---|---|---|---|
| Problema | Ridicare la putere in timp logaritmic | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.54 kb |
#include<stdio.h>
#define m 1999999973
using namespace std;
int n, p;
long long sol = 1;
void exp(int n, int p)
{
int i;
long long mt;
mt = n;
for(i = 0; (1<<i) <= p; i++)
{
if((1<<i) & p)
sol = (sol * mt) % m;
mt = (mt * mt) % m;
}
}
int main()
{
freopen("lgput.in", "r", stdin);
freopen("lgput.out", "w", stdout);
scanf("%d %d", &n, &p);
exp(n, p);
printf("%lld", sol);
fclose(stdin);
fclose(stdout);
return 0;
}
