Cod sursa(job #2231003)

Utilizator IMIR33Iacob-Mare Ionut Radu IMIR33 Data 12 august 2018 16:52:25
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.66 kb
#include <iostream>
#include <fstream>
#define mod 1999999973

using namespace std;

ifstream f ("lgput.in");
ofstream g ("lgput.out");

int N, P;

int ridicare_la_putere(int n, int p)
{
    if (p < 0)
        return ridicare_la_putere(1 / n, -p);
    else if (p == 0)
            return 1;
        else if (p == 1)
                return n;
            else if (!(p % 2))
                    return ridicare_la_putere(n * n, p / 2) % mod ;
                else if (p % 2)
                        return n % mod * ridicare_la_putere(n * n, (p - 1) / 2) % mod;
}

int main()
{
    f >> N >> P;
    g << ridicare_la_putere(N, P);
    return 0;
}