Cod sursa(job #1435791)
Utilizator | Data | 14 mai 2015 15:58:52 | |
---|---|---|---|
Problema | Invers modular | Scor | 90 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.4 kb |
#include<fstream>
#include<vector>
using namespace std;
ifstream cin("inversmodular.in");
ofstream cout("inversmodular.out");
int a,n,x,y,d;
int gcd(int a ,int b, int &x, int &y){
if (!b) return x=1,y=0,a;
int x1,y1;
int g=gcd(b,a%b,x1,y1);
x=y1;
y=x1-y1*(a/b);
return g;
}
int main()
{
cin>>a>>n;
d=gcd(a,n,x,y);
x=((x%n)+n)%n;
cout<<x;
return 0;
}