Pagini recente » Cod sursa (job #1063791) | Cod sursa (job #1962078) | Cod sursa (job #393145) | Cod sursa (job #1380135) | Cod sursa (job #2049066)
#include <iostream>
#include <fstream>
// A * X mod N = 1
std::ifstream cin("inversmodular.in");
std::ofstream cout("inversmodular.out");
int A, N, nr, a, b, c;
int euclid(int a, int b, int &x, int &y)
{
if (b == 0) {
x = 1;
y = 0;
return a;
}
int x0, y0, d;
d = euclid(b, a % b, x0, y0);
x = y0;
y = x0 - (a / b) * y0;
return d;
}
int main () {
cin >> A >> N;
c = 1;
int x, y, d;
d = euclid(A, N, x, y);
cout << x * (c / d);
return 0;
}