Cod sursa(job #1229774)

Utilizator afkidStancioiu Nicu Razvan afkid Data 18 septembrie 2014 08:23:26
Problema Ridicare la putere in timp logaritmic Scor 30
Compilator cpp Status done
Runda Arhiva educationala Marime 0.55 kb
#include <cstdio>
#define mod 1999999973

using namespace std;

long long n,p;

long long power(long long a,long long b)
{
    long long k;
    if(b==0)
        return 1;
    else if(b==1)
        return a;
    else if(b%2==0)
    {
        k=power(a,b/2);
        return (k*k)%mod;
    }
    else
    {
        k=power(a,b/2);
        return (k*(k*a)%mod)%mod;
    }
}

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