Cod sursa(job #1230435)

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

using namespace std;

long long power(long long a,long long b)
{
    long long k;
    if(b==0)
        return 1;
    else if(b==1)
        return a%mod;
    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()
{
    long long n,p;
    freopen("lgput.in","r",stdin);
    freopen("lgput.out","w",stdout);
    scanf("%lld %lld",&n,&p);
    printf("%lld",power(n,p));
    return 0;
}