Cod sursa(job #2231002)

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

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);
                else if (p % 2)
                        return n * ridicare_la_putere(n * n, (p - 1) / 2);
}

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