Cod sursa(job #3134977)

Utilizator Tulbure_Alexandru_NicolaeTulbure Alexandru Nicolae Tulbure_Alexandru_Nicolae Data 1 iunie 2023 10:36:37
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator c-64 Status done
Runda Arhiva educationala Marime 0.55 kb
#include <stdio.h>
#define M 1999999973

FILE *fin = NULL, *fout = NULL;
long long n, p, rez = 1;

long long ridic(long long n, long long p);

int main()
{
    fin = fopen("lgput.in", "r");
    fout = fopen("lgput.out", "w");
    fscanf(fin, "%lld %lld", &n, &p);
    fprintf(fout, "%lld", ridic(n, p));
    fclose(fin);
    fclose(fout);
    return 0;
}

long long ridic(long long n, long long p)
{
    while (p)
    {
        if (p % 2 == 1)
        {
            rez = (rez * n) % M;
        }
        n = (n * n) % M;
        p /= 2;
    }
    return rez % M;
}