Pagini recente » Cod sursa (job #3201792) | Cod sursa (job #2447964) | Cod sursa (job #1791173) | Cod sursa (job #23944) | Cod sursa (job #2909302)
#include <stdio.h>
#include <iostream>
#include <fstream>
#include <math.h>
// https://infoarena.ro/problema/inversmodular
// a * x + b * y = d
void euclid3(int a, int b, int* d, int* x, int* y)
{
if (b == 0) {
*d = a;
*x = 1;
*y = 0;
}
else {
int x0, y0;
euclid3(b, a % b, d, &x0, &y0);
*x = y0;
*y = x0 - (a / b) * y0;
}
}
int main() {
std::ifstream fin("inversmodular.in");
std::ofstream fout("inversmodular.out");
int A, N, x, y, d;
d = 1;
x = 0;
y = 0;
fin >> A;
fin >> N;
euclid3(A, N, &d, &x, &y); // A * X + N * Y = 1
fout << x;
fin.close();
fout.close();
return 0;
}