Pagini recente » Borderou de evaluare (job #1796799) | Cod sursa (job #362198) | Cod sursa (job #1006757) | Cod sursa (job #769467) | Cod sursa (job #3000474)
#include <fstream>
#define ll long long
using namespace std;
ifstream cin("inversmodular.in");
ofstream cout("inversmodular.out");
int a,n;
void cmmdc(ll &x, ll &y, int a, int b)
{
if (!b)
x = 1, y = 0;
else
{
cmmdc(x, y, b, a % b);
ll aux = x;
x = y;
y = aux - y * (a / b);
}
}
int main(void)
{
ll inv=0,ins;
cin>>a>>n;
cmmdc(inv,ins,a,n);
if(inv<=0)
inv=n+inv%n;
cout<<inv;
}