Cod sursa(job #3356275)

Utilizator Car13Carmi Carabas Car13 Data 30 mai 2026 15:36:06
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.64 kb
#include <iostream>
#include <fstream>
#include <cstdint>

using namespace std;

ifstream fin("lgput.in");
ofstream fout("lgput.out");

unsigned long long exponent_log(long long n, int p){
    if(p == 0){
        return 1;
    }
    if(p % 2 == 0){
        return (exponent_log((n * n) % 1999999973, p / 2)) ;
    }
    if(p % 2 == 1){
        return (n * (exponent_log((n * n)% 1999999973, p / 2))) % 1999999973;
    }
    return 0;
}

int main (){
    unsigned long long n, p;
    unsigned long long r = 1;
    fin >> n >> p;
    r = exponent_log(n, p);
    fout << r;
    fin.close();
    fout.close();
    return 0;
}