Cod sursa(job #180642)

Utilizator DraStiKDragos Oprica DraStiK Data 17 aprilie 2008 12:27:10
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.51 kb
#include <stdio.h>
const int m=1999999973;
long long unsigned n,p;
long long unsigned put (long long unsigned n,long long unsigned p)
{
    if (p==0)
        return 1;
    else if (p%2==0)
        return put (((n%m)*(n%m))%m,p/2);
    else if (p%2==1)
        return (n%m)*put (((n%m)*(n%m))%m,(p-1)/2);
}
int main ()
{
    freopen("lgput.in","r",stdin);
    freopen("lgput.out","w",stdout);
    long long unsigned d;
    scanf ("%llu%llu",&n,&p);
    d=put (n,p);
    printf ("%llu",d);
    return 0;
}