Pagini recente » Cod sursa (job #3356966) | Cod sursa (job #3322633) | Cod sursa (job #1201772) | Cod sursa (job #2109144) | Cod sursa (job #3357018)
#include <stdio.h>
typedef long long ll;
ll extended_gcd(ll a, ll b, ll *x, ll *y) {
if (b == 0) {
*x = 1; *y = 0;
return a;
}
ll x1, y1;
ll g = extended_gcd(b, a % b, &x1, &y1);
*x = y1;
*y = x1 - (a / b) * y1;
return g;
}
int main() {
FILE *fin = fopen("inversmodular.in", "r");
FILE *fout = fopen("inversmodular.out", "w");
ll a, n;
fscanf(fin, "%lld %lld", &a, &n);
ll x, y;
extended_gcd(a, n, &x, &y);
x = ((x % n) + n) % n;
fprintf(fout, "%lld\n", x);
fclose(fin);
fclose(fout);
return 0;
}