Cod sursa(job #1689276)

Utilizator TimitocArdelean Andrei Timotei Timitoc Data 14 aprilie 2016 08:50:08
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.48 kb
#include <iostream>
#include <cstdio>
#define MOD 1999999973

using namespace std;

int rise(long long n, long long p)
{
	long long rez = 1;
    for (long long i = 0; p>>i; i++) {
        if ((p>>i)&1)
			rez = (rez*n) % MOD;
		n = (n*n) % MOD;
    }
    return (int)rez;
}

int main()
{
    freopen("lgput.in", "r", stdin);
    freopen("lgput.out", "w", stdout);

    long long n, p;
    scanf("%lld %lld", &n, &p);
    int rez = rise((n%MOD), p);
	printf("%d\n", rez);

    return 0;
}