Cod sursa(job #651444)
Utilizator | Data | 20 decembrie 2011 14:07:51 | |
---|---|---|---|
Problema | Invers modular | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.5 kb |
#include <cstdio>
using namespace std;
void GCD (int A, int B, int &X, int &Y)
{
if (B==0)
{
X=1;
Y=0;
return;
}
int X0, Y0;
GCD (B, A%B, X0, Y0);
X=Y0;
Y=X0-Y0*(A/B);
}
int main()
{
freopen ("inversmodular.in", "r", stdin);
freopen ("inversmodular.out", "w", stdout);
scanf ("%d %d", &A, &N);
int X, Y;
GCD (A, N, X, Y);
if (X<0)
{
X=N+X%N;
}
printf ("%d\n", X);
return 0;
}