Cod sursa(job #2659206)

Utilizator martinmiere133Cranga Antonio martinmiere133 Data 16 octombrie 2020 09:45:03
Problema Invers modular Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.68 kb
#include <iostream>
#include <fstream>
#include <vector>
#include <queue>
#include <set>
#include <algorithm>
#include <list>
#include <map>
#include <math.h>
#define NMAX 100001
using namespace std;
ifstream f("inversmodular.in");
ofstream g("inversmodular.out");
typedef pair<int,int> p;
p euclid(int a , int b,  int c)
{
    if(b == 0)
    {
        if(c%a)return make_pair(0, 0);
        else return make_pair(c/a, 0);
    }
    else
    {
        p rez = euclid(b, a%b, c);
        return make_pair(rez.second, rez.first - a/b * rez.second);
    }
}
int main() {
    int a , b;
    f>>a>>b;
    auto rez = euclid(a, b, 1);
    int r = rez.first;
    if(r<0)r+=b;
    g<<r;
    return 0;
}