Pagini recente » Cod sursa (job #2814980) | Cod sursa (job #2444874) | Cod sursa (job #3276345) | Cod sursa (job #646364) | Cod sursa (job #663652)
Cod sursa(job #663652)
#include <cstdio>
using namespace std;
long long x,y;
int a,b,c,d,n,i,x0,y0;
void inversm(int a, int b, long long &x, long long &y)
{
long long k;
if (b==0)
{
x=1;
y=0;
}
else
{
inversm(b,a%b,x,y);
k=x;
x=y;
y=k-(a/b)*y;
}
}
int main()
{
freopen("inversmodular.in","r",stdin);
freopen("inversmodular.out","w",stdout);
scanf("%d%d\n",&a,&n);
inversm(a,n,x,y);
while (x<0)
x=n+x%n;
printf("%d\n",x);
fclose(stdin);
fclose(stdout);
return 0;
}