Cod sursa(job #807849)
| Utilizator | Data | 5 noiembrie 2012 20:06:38 | |
|---|---|---|---|
| Problema | Ridicare la putere in timp logaritmic | Scor | 10 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.41 kb |
#include<cstdio>
using namespace std;
#define m 1999999973
void read(),solve();
int n,p,b,r,e;
int main()
{
read();
solve();
return 0;
}
void read()
{
freopen("lgput.in","r",stdin);
freopen("lgput.out","w",stdout);
scanf("%d %d",&n,&p);
}
void solve()
{
for(b=n,r=1,e=p;e;e/=2)
{
if(e%2==1) r=(r*b)%m;
b=(b*b)%m;
}
printf("%d ",r);
}
