Pagini recente » Istoria paginii runda/oni_gim2016/clasament | Cod sursa (job #984411) | Cod sursa (job #1703107) | Cod sursa (job #830794) | Cod sursa (job #2900665)
#include <fstream>
using namespace std;
#define int long long
const string filename = "inversmodular";
ifstream fin(filename + ".in");
ofstream fout(filename + ".out");
///x0 * b + y0 * (a - (a/b) * b) = x * a + y * b
void big_euclid(int a, int b, int &x, int &y)
{
if(b == 0)
{
x = 1;
y = 0;
return;
}
big_euclid(b, a % b, x, y);
int x0 = x, y0 = y;
x = y0;
y = x0 - y0 * (a / b);
}
signed main()
{
int n, a, x, y;
fin >> a >> n;
big_euclid(n, a, x, y);
while(y < 0)
y += n;
fout << y;
return 0;
}