Cod sursa(job #3304890)

Utilizator AndreiRares1801Andrei Acatrini AndreiRares1801 Data 28 iulie 2025 13:21:35
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.47 kb
#include <iostream>
#include <fstream>
using namespace std;

#ifdef LOCAL
#define fin cin
#define fout cout
#else
ifstream fin("lgput.in");
ofstream fout("lgput.out");
#endif

const int MOD = 1999999973;

int exp(long long int b, long long int p) {
	if (p == 0) return 1;
	int put = exp(b, p / 2);
	if (p % 2 == 0) return (1LL * put * put) % MOD;
	else return (1LL * b * (put * put) % MOD) % MOD;
}

int main() {
	long long int n, p;
	fin >> n >> p;
	fout << exp(n % MOD, p);
}