Cod sursa(job #3169116)

Utilizator Redstoneboss2Fabian Lucian Redstoneboss2 Data 14 noiembrie 2023 11:27:11
Problema Invers modular Scor 50
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.68 kb
#include <iostream>
#include <fstream>

using namespace std;

#define cin fin
#define cout fout

ifstream fin("inversmodular.in");
ofstream fout("inversmodular.out");

void euclid(long long a, long long b, long long& x, long long& y, int MOD = -1);

int main()
{
    long long a, n, x, y;

    cin >> a >> n;

    euclid(a, n, x, y);

    cout << x;

    return 0;
}

void euclid(long long a, long long b, long long& x, long long& y, int MOD)
{
    if(MOD == -1)
    {
        MOD = b;
    }

    if(b == 0)
    {
        y = 0;
        x = 1;
    }
    else
    {
        long long x1, y1;

        euclid(b, a % b, x1, y1, MOD);

        x = y1 % MOD;
        y = (x1 - a / b * y1) % MOD;
    }
}