Cod sursa(job #1206863)

Utilizator LunguIoanAdrianLungu Ioan Adrian LunguIoanAdrian Data 11 iulie 2014 13:16:17
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.69 kb
#include <iostream>
#include <fstream>
using namespace std;

int RidicareLog(long long nr, long long ex);
long long tip;
long long put(long n, long p)
{
 if(p==0) return 1;
 if(p%2==1)
 return (n*put(n,p-1));
 tip=put(n,p/2);
 return tip*tip;
}
int main()
{
    ifstream in("lgput.in");
    ofstream out("lgput.out");
    long long n,p;
    in >> n >> p;
   // out << RidicareLog(n,p)%1999999973;
      out << put(n,p)%1999999973;
    return 0;
}

int RidicareLog(long long nr, long long ex)
{
    long long p=1;
    while(ex>0)
    {
        if(ex%2!=0)
        {
            p=p*nr;
            ex--;
        }
        nr=nr*nr;
        ex=ex/2;
    }
    return p;
}