Cod sursa(job #1997532)

Utilizator andreismara97Smarandoiu Andrei andreismara97 Data 4 iulie 2017 17:39:29
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.51 kb
#include <cstdio>

using namespace std;

int main()
{
    const int modulo = 1999999973;
    int n, p;
    long long nr = 1;
    freopen("lgput.in", "r", stdin);
    freopen("lgput.out", "w", stdout);

    scanf("%d%d", &n, &p);
    long long a = n;
    for( int i = 0; (1<<i) <= p; i++ ) // parcurgem fiecare bit din p
    {
        if( ((1<<i) & p) > 0 ) //bitul i din p este 1
            nr = ( nr * a ) % modulo;
        a = ( a * a ) % modulo;
    }
    printf("%lld\n", nr);
    return 0;
}