Cod sursa(job #2351463)

Utilizator cristina-criCristina cristina-cri Data 22 februarie 2019 13:31:49
Problema Invers modular Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.51 kb
#include <cstdio>
#include <algorithm>

using namespace std;

int a, n;

pair <int, int> euclid(int a, int b)
{
    if(b == 0)
        return {1, 0};
    auto p=euclid(b, a%b);
    return {p.second, p.first-(a/b)*p.second};
}


int main()
{

    freopen("inversmodular.in", "r", stdin);
    freopen("inversmodular.out", "w", stdout);


    scanf("%d %d", &a, &n);
    auto invers=euclid(a, n);
    int inv=invers.first;
    while(inv<0)
        inv+=n;
    printf("%d", inv);
    return 0;
}