其实这个同余方程就是
就想是 减掉若干个 剩下的
即 ,然后直接用 ,求出来 就可以了,然后 求出来也不用管了,因为要正整数解,所以求出来一个 ,就要输出
代码
#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;
}