Pagini recente » Cod sursa (job #1989047) | Cod sursa (job #2334375) | Cod sursa (job #304624) | Cod sursa (job #1889864) | Cod sursa (job #2787795)
#include <bits/stdc++.h>
typedef long long ll;
using namespace std;
ifstream fin("inversmodular.in");
ofstream fout("inversmodular.out");
/// A>=1 si N>=2 doua numere naturale
/// 1<=A<=N-1 cu (A,N)=1 prime intre ele
/// 1<=X<=N-1 inversul modular => A*X congruent cu 1 modulo N
ll A, N, x, y;
void euclid(ll a, ll b)
{
if(b==0){
x=1;
y=0;
return;
}
euclid(b,a%b);
x=x-a/b*y;
swap(x,y);
}
int main()
{
fin>>A>>N;
euclid(A,N);
if(x<0)
x=N+x%N;
fout<<x;
fin.close();
fout.close();
return 0;
}