a x ≡ 1 ( m o d b ) a x \equiv 1 \pmod b ax≡1(modb)
其实这个同余方程就是 a x m o d = 1 ax\bmod =1 axmod=1
就想是 a x ax ax减掉若干个 b b b剩下的 1 1 1
即 a x − b y = 1 ax-by=1 ax−by=1,然后直接用 e x g c d exgcd exgcd,求出来 x x x就可以了,然后 y y y求出来也不用管了,因为要正整数解,所以求出来一个 x x x,就要输出 ( x m o d b + b ) m o d b (x\bmod b+b)\bmod b (xmodb+b)modb
代码
#include<bits/stdc++.h>
using namespace std;
void exgcd(int a,int b,int &x,int &y){
if(b==0){x=1;y=0;return;}
exgcd(b,a%b,x,y);
int t=x;
x=y;
y=t-a/b*y;
}
int a,b,x,y;
int main(){
scanf("%d%d",&a,&b);
exgcd(a,b,x,y);
printf("%d",(x%b+b)%b);
return 0;
}