Cod sursa(job #1304558)

Utilizator ovidiuz98Zamfir Ovidiu ovidiuz98 Data 28 decembrie 2014 23:36:55
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.41 kb
#include <fstream>
#define MOD 1999999973
using namespace std;

ifstream fin("lgput.in");
ofstream fout("lgput.out");
int n,p;
int putere(int n,int p){
    if(p==0)
        return 1;
    if(p==1)
        return n%MOD;
    if(p%2==0)
        return putere((n*n)%MOD,p/2);
    return (n*putere((n*n)%MOD,p/2))%MOD;
}
int main(){
    fin>>n>>p;
    fout<<putere(n,p);
    fin.close();fout.close();
}