Cod sursa(job #931588)
| Utilizator | Data | 28 martie 2013 12:56:16 | |
|---|---|---|---|
| Problema | Invers modular | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.53 kb |
#include <iostream>
#include <fstream>
using namespace std;
int A,N;
void euclid(int a,int b,int &d,int &x,int &y)
{
if(b==0)
{
d=a;
x=1;
y=0;
return;
}
int x0,y0;
euclid(b,a%b,d,x0,y0);
x=y0;
y=x0-(a/b)*y0;
}
int main()
{
ifstream fin("inversmodular.in");
ofstream fout("inversmodular.out");
fin>>A>>N;
int x,y,d;
euclid(A,N,d,x,y);
if(x<=0)
x=N+x%N;
fout<<x;
fout.close();
fin.close();
return 0;
}
