Cod sursa(job #577757)

Utilizator TeodoraTanaseTeodora Tanase TeodoraTanase Data 10 aprilie 2011 16:08:15
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.49 kb
#include <cstdio>

using namespace std;

const long long m=1999999973;
long long n, p, r;

long long f(long long p)
{
    if (p==1)
        return n%m;
    if (p%2)
    {
        long long c=f(p-1)%m;
        return (n*c)%m;
    }
    else
    {
        long long c=f(p/2)%m;
        return (c*c)%m;
    }
}

int main()
{
    freopen ("lgput.in","r",stdin);
    freopen ("lgput.out","w",stdout);
    scanf ("%lld %lld",&n,&p);
    printf("%lld\n",f(p));
    return 0;
}