Cod sursa(job #3243099)
Utilizator | Data | 15 septembrie 2024 18:04:48 | |
---|---|---|---|
Problema | Invers modular | Scor | 0 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.45 kb |
#include <iostream>
using namespace std;
int gcd(int a, int b, int& x, int& y)
{
if(b==0)
{
x=1, y=0;
return a;
}
int x1, y1;
int d=gcd(b, a%b, x1, y1);
x=y1;
y=x1-y1*(a/b);
return d;
}
int main()
{
ifstream cin("inversmodular.in");
ofstream cout("inversmodular.out");
int a, m, x, y;
cin>>a>>m;
int g=gcd(a, m, x, y);
x=(x%m+m)%m;
cout<<x;
return 0;
}