Cod sursa(job #180662)

Utilizator DraStiKDragos Oprica DraStiK Data 17 aprilie 2008 12:52:46
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.51 kb
#include <stdio.h>
#define 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))%m;
}
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;
}