Cod sursa(job #482053)

Utilizator CossAlbulescu Cosmina Coss Data 2 septembrie 2010 14:15:32
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.56 kb
#include <stdio.h>
using namespace std;

#define MOD 1999999973

int bin[10001];
long long p, N, rez = 1;
int i, j;

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

    while (p)
    {
        i ++;
        bin[i] = p % 2;
        p /= 2;
    }

    for (j=i; j>=1; --j)
    {
        rez = (rez * rez) % MOD;
        if (bin[j])
            rez = (rez * N) % MOD;
    }

    fprintf (g, "%lld\n", rez);

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