Cod sursa(job #1730034)

Utilizator andreis181andreis181 andreis181 Data 16 iulie 2016 04:47:27
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.45 kb
#include <iostream>
#include <fstream>
using namespace std;
const int m = 1999999973;

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

int main()
{
    ifstream f("lgput.in");
    ofstream g("lgput.out");
    int n,p;
    f>>n>>p;
    g<<put(n,p);
}