Cod sursa(job #3304887)

Utilizator AndreiRares1801Andrei Acatrini AndreiRares1801 Data 28 iulie 2025 13:14:02
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;

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

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