Cod sursa(job #1464066)

Utilizator SolcanMihaiSolcan Mihai Andrei SolcanMihai Data 22 iulie 2015 11:26:03
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.6 kb
#include <cstdio>
#include <cstring>
#include <cstdlib>
#define MOD 1999999973

using namespace std;

long long solve(long long x, long long p)
{
    if(p == 0)
    {
        return 1;
    }
    else
    {
        if(p % 2 == 0)
        {
            return solve((x * x) % MOD, p / 2);
        }

        return (solve(x, p - 1) * x) % MOD;

    }
}

int main()
{
    freopen("lgput.in", "r", stdin);
    freopen("lgput.out", "w", stdout);

    long long x, p, prod;

    scanf("%lld %lld", &x, &p);

    prod = solve(x, p);

    printf("%lld", prod);

    return 0;
}