Cod sursa(job #1326919)

Utilizator tudor_bonifateTudor Bonifate tudor_bonifate Data 26 ianuarie 2015 10:42:36
Problema Ridicare la putere in timp logaritmic Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.51 kb
#include <iostream>
#include <fstream>
#define MOD 1999999973
using namespace std;
long long n,p,x;
ifstream f("putere.in");
ofstream g("putere.out");
int putere(long long n, long long p)
{
    if (p<0) return putere(1/n, p*(-1));
    if (p==0) return 1;
    if (p==1) return n%MOD;
    if (p%2==0) return (putere(n*n%MOD, p/2))%MOD;
    if (p%2==1) return (n*putere(n*n%MOD, p/2))%MOD;
}
    int main()
    {
        f>>n>>p;
        putere(n,p);
        g<<putere(n,p);
        return 0;
    }