Cod sursa(job #3357058)

Utilizator SimionescuGabrielSimionescu Gabriel SimionescuGabriel Data 5 iunie 2026 15:54:25
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator c-64 Status done
Runda Arhiva educationala Marime 0.47 kb
#include <stdio.h>
const int rst = 1999999973;
long long explog(long long x, long long n) {
  long long sol = 1;
  if (n == 0)
    return 1;
  for (long long i = 0; (1 << i) <= n; ++i) {

    if (((1 << i) & n) > 0)
      sol = (sol*x) % rst;
    x = (x*x)%rst;
  }
  return sol;
}

int main(void) {

  FILE *in = fopen("lgput.in", "r");
  FILE *out = fopen("lgput.out", "w");
  long long n, p; 
  fscanf(in, "%lld %lld", &n, &p);

  fprintf(out, "%lld", (explog(n, p)));
  return 0;
}