Pagini recente » Cod sursa (job #977707) | Cod sursa (job #2186078) | Cod sursa (job #952597) | Cod sursa (job #1472834) | Cod sursa (job #487293)
Cod sursa(job #487293)
#include <stdio.h>
#include <math.h>
long n, m, put;
long long val, rez;
int main() {
freopen("inversmodular.in", "r", stdin);
freopen("inversmodular.out", "w", stdout);
scanf("%ld %ld", &n, &m);
put = m - 2; rez = 1; val = n;
while (put) {
if (put & 1) {
rez *= 1LL * val;
rez %= m * 1LL;
}
put >>= 1;
val *= 1LL * val;
val %= 1LL * m;
}
printf("%lld\n", rez);
return 0;
}