Cod sursa(job #1244673)
Utilizator | Data | 17 octombrie 2014 23:09:43 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 10 |
Compilator | c | Status | done |
Runda | Arhiva educationala | Marime | 0.55 kb |
#include <stdio.h>
#define IN "lgput.in"
#define OUT "lgput.out"
static const unsigned long mod = 1999999973;
static unsigned long lgput(unsigned long n, unsigned long p)
{
if (p == 0)
return 1;
if (p == 1)
return n;
if (p % 2)
return (n * lgput(n * n, (p - 1) >> 1)) % mod;
else
return lgput(n * n, p >> 1) % mod;
}
int main(void)
{
unsigned long p, n;
freopen(IN, "r", stdin);
freopen(OUT, "w", stdout);
scanf("%lu %lu", &n, &p);
printf("%lu\n", lgput(n, p) % mod);
return 0;
}