Cod sursa(job #1099172)

Utilizator BlueStrutAndrei Prahoveanu BlueStrut Data 5 februarie 2014 17:02:13
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.36 kb
#include<cstdio>
using namespace std;
long long i, n, p, a, sol;
int main(){
    freopen("lgput.in","r",stdin);
    freopen("lgput.out","w",stdout);
    scanf("%lld%lld", &n, &p);
    sol=1; a=n;
    for (i=0;(1<<i)<=p;++i) {
        if (((1<<i)&p)>0) sol=(sol*a)%1999999973;
        a=(a*a)%1999999973;
    }
    printf("%lld\n", sol);
    return 0;
}