Cod sursa(job #2063721)
Utilizator | Data | 11 noiembrie 2017 13:32:13 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 0 |
Compilator | c | Status | done |
Runda | Arhiva educationala | Marime | 0.35 kb |
#include <stdio.h>
int putere (int n, int p){
int aux = n, rez = 1, putere = 1;
while (p){
while (putere * 2 <= p){
aux *= aux;
putere *= 2;
aux %= 1999999973;
}
p = p - putere;
rez *= aux;
aux = n;
putere = 1;
rez %= 1999999973;
}
return rez;
}
int main(){
int n, p;
scanf ("%d%d", &n, &p);
printf ("%d\n", putere (n, p));
}