Cod sursa(job #3298371)

Utilizator Bolbotina_David-AndreiBolbotina David-Andrei Bolbotina_David-Andrei Data 29 mai 2025 10:02:11
Problema Ridicare la putere in timp logaritmic Scor 90
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.47 kb
/******************************************************************************

                              Online C++ Compiler.
               Code, Compile, Run and Debug C++ program online.
Write your code in this editor and press "Run" button to compile and execute it.

*******************************************************************************/

#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("lgput.in");
ofstream fout("lgput.out");

/*long long exp_log(short x, long long n, int mod,long long expo) {
	if(n < 0) {
		x = 1.0 / x;
		n = (-1) * n;
	}
	if(n == 0) return 1;
	long long p = 1;
	x = x % mod;
	while(expo > 1) {
		if((n >> (expo-1)) % 2 == 1) {
			p = (p * x) % mod;
		}
		p = (p * p) % mod;
		expo--;
	}
	return p;
}

long long binar(long long n, long long &expo){
    long long rez=0;
    expo = 1;
    while(n){
        rez = rez + expo * (n%2);
        expo*=10;
        n/=2;
    }
    expo/=10;
    long long p = expo;
    expo = 0;
    while(p){
        expo +=1;
        p/=10;
    }
    return rez;
}*/

long long exp_log(long long x, long long n, int mod) {
    long long p = 1;
    x = x % mod;
    while (n > 0) {
        if (n % 2)
            p = (p * x) % mod;
        x = (x * x) % mod;
        n /= 2;
    }
    return p;
}


int main()
{
    short n;
	long long p;
	fin>>n>>p;
	int mod = 1999999973;
	long long s = exp_log(n, p, mod);
	fout<<s;

	return 0;
}