Cod sursa(job #2488850)

Utilizator bogdanvladmihaiBogdan Vlad-Mihai bogdanvladmihai Data 7 noiembrie 2019 18:15:34
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.47 kb
#include <bits/stdc++.h>

const int MOD = 1999999973;

int a, b;

long long lgpow(int base, int exp) {
  long long ans = 1;
  while (exp > 0) {
    if ((exp & 1) > 0) {
      ans = (1LL * ans * base) % MOD;
    }
    exp >>= 1;
    base = (1LL * base % MOD * base) % MOD;
  }
  return ans % MOD;
}

int main() {
  freopen("lgput.in", "r", stdin);
  freopen("lgput.out", "w", stdout);
  scanf("%d %d", &a, &b);
  printf("%lld", lgpow(a, b) % MOD);
  return 0;
}