Cod sursa(job #465301)

Utilizator miculprogramatorA Cosmina - vechi miculprogramator Data 23 iunie 2010 20:08:34
Problema Ridicare la putere in timp logaritmic Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.6 kb
#include <stdio.h>
using namespace std;

#define MOD 1999999973

long N, P;

long long ridicare_la_putere (long n, long p)
{
    long long rez;
    if (p == 0)
        return 1;
    if (p % 2 == 1)
        return (ridicare_la_putere(n*ridicare_la_putere(n, p - 1)) % MOD);
    else
        rez = ridicare_la_putere(n, p / 2) % MOD;
    return rez * rez % MOD;
}

int main ()
{
    FILE *f = fopen ("lgput.in","r");
    FILE *g = fopen ("lgput.out","w");
    fscanf (f,"%ld %ld", &N, &P);

    fprintf (g,"%lld", ridicare_la_putere(N,P));

    fclose(g);
    fclose(f);
    return 0;
}