Cod sursa(job #3134968)
| Utilizator | Data | 1 iunie 2023 09:32:19 | |
|---|---|---|---|
| Problema | Ridicare la putere in timp logaritmic | Scor | 0 |
| Compilator | c-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.51 kb |
#include <stdio.h>
#define M 1999999973
FILE *fin = NULL, *fout = NULL;
long long n , p, rez;
long long ridic(long long n, long long p)
{
while (p)
{
if (p % 2 == 1)
{
p--;
rez = (rez * n) % M;
}
n = (n * n) % M;
p /= 2;
}
return rez % M;
}
int main()
{
fin = fopen("lgput.in","r");
fout = fopen("lgput.out","r");
fscanf(fin,"%lld %lld",&n,&p);
fprintf(fout,"%lld",ridic(n,p));
fclose(fin);
fclose(fout);
return 0;
}