Pagini recente » Cod sursa (job #2913243) | Diferente pentru implica-te/arhiva-educationala intre reviziile 197 si 198 | Cod sursa (job #1177817) | Cod sursa (job #1904497) | Cod sursa (job #3286908)
#include <fstream>
#include <cmath>
using namespace std;
ifstream cin("inversmodular.in");
ofstream cout("inversmodular.out");
void euclid(int a , int b ,int & x ,int & y)
{
if(b == 0)
{
x = 1, y = 1;
}
else
{
int x1 , y1;
euclid(b , a % b , x1 , y1);
x = y1;
y = x1 - a / b * y1;
}
}
int main()
{
//int A = 5, N = 7; // prime intre ele, 1 <= A < N
int A,N;
cin>>A>>N;
int X , Y;
euclid(A, N , X ,Y);
while(X < 0)
X += N;
cout << X; // 5
return 0;
}