Cod sursa(job #2779637)

Utilizator casiannCasian casiann Data 4 octombrie 2021 15:48:23
Problema Ridicare la putere in timp logaritmic Scor 40
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.43 kb
#include <bits/stdc++.h>
using namespace std;

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

const int m = 1999999973;
long long n;
unsigned int p_actual, p, baza;

int main(){
    long long p_actual = 1, baza;
    fin >> n >> p;
    baza = n;
    while(p_actual*2 <= p){
        n = (n*n) % m;
        p_actual *=2;
    }
    for(int i=1; i<=p-p_actual; i++) n = (n*baza) % m ;
    fout << n; 
    return 0;
}