浅谈 exgcd

众所周知欧几里得算法是:

gcd(a,b)=gcd(b,amodb)

也叫辗转相除法。

拓展欧几里得算法(exgcd),可以用来找到形如 ax+by=gcd(a,b) 的方程的一组特解

由裴蜀定理知,原方程一定有解。

我们利用辗转相除法(普通欧几里得算法)。

我们设 d=gcd(a,b)

我们可以知道,我们辗转相除法的边界是 a=d,b=0,此时我们可以知道 a 就是最大公约数,我们还可以知道,在这时一定有一解为 x=1,y=0,即 1×a+0×b=d

我们知道 gcd(a,b)=gcd(b,amodb),如果我们可以推导出每一次的解 xy,与相除后的解 xy 的关系;我们就可以算出其中的一个解了,(xy 相当于是 ab 的解,xya 变成了 bb 变成了 amodb 时的解(辗转相除))。

轻易得知:

{ax+by=dbx+(amodb)y=d

则:

bx+(abab)y=dbx+aybaby=day+b(xaby)=d解得:{x=yy=xaby

然后我们知道 xxyy, 的关系后就可以求解了:

#include<iostream>
#include<cstdio>
using namespace std;
void exgcd(int a,int b,int& x,int& y) //x.y也可以用pair返回,这里用了引用
{
	if (!b){x=1;y=0;return ;}     //边界
	gcd(b,a%b);                   //辗转相除
	int tmp=y;y=x-(a/b)*y;x=tmp;  //套公式
}
int main()
{
	int a,b,x,y;
	scanf("%d %d",&a,&b);
	exgcd(a,b,x,y);
	printf("%d %d",x,y);
	return 0;
}
posted @   yspm  阅读(347)  评论(1编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
😅​
点击右上角即可分享
微信分享提示