扩展欧几里得算法(2)

本文深入解析扩展欧几里得定理,包括定理的实现、解法推导及其在不定式方程中的应用。通过具体例子阐述了如何找到一组解,并进一步推导出该方程的一般解形式,最后介绍了如何获取所有满足条件的解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先、扩展欧几里得定理:对于两个不全为0的整数a、b,必存在一组解x,y,使得ax+by==gcd(a,b);

实现如下:

复制代码
int gcd(int a,int b)
{
int t,d;
if(b==0)
{
x
=1;
y
=0; //不明处1
return a;
}
d
=gcd(b,a%b);
t
=x;
x
=y;
y
=t-(a/b)*y; //不明处2
return d;
}
复制代码

上面的程序中,x和y我是用全局变量保存的

我个人觉得第一次看到这个程序你会有以上两个不明白的地方(见注释),下面我分别解释

不明处1:由扩展欧几里得定理:ax+by==gcd(a,b)---式1,而此时b==0,也就是说gcd(a,0)==a。原式变为ax+by==a --> x==1,y==0。应该够清楚了吧

不明处2:这里先说明一下我的一些规则,x,y表示第一次递归时的值,x1,y1表示第二次递归时的值。那么

gcd(a,b)==gcd(b,a%b),同时都代入式1,有ax+by==b*x1+(a%b)*y1。将右边变形一下

b*x1+(a%b)*y1==b*x1+(a-(a/b)*b)*y1==a*y1+b*(x1-(a/b)*y1),最终得到ax+by==a*y1+b*(x1-(a/b)*y1)

也就是说,上一深度的x等于下一深度的y1,上一深度的y等于下一深度的x1-(a/b)*y1。    需要注意,上面推导时用的除法都是整型除法

 

到这里为止,我们便得到了不定式ax+by==gcd(a,b)的一组解,x、y。

那么对于一般的不定式ax+by==c,它的解应该是什么呢。很简单,x1=x*(c/gcd(a,b)),y1=y*(c/gcd(a,b))。很好理解吧~

 

再深入一点,就解出这么一组解其实一般来说是解决不了什么问题的。没有哪个ACM的题这么简单吧。。。比如我们现在要得到所有的解,那么这所有的解究竟是什么呢?

直接说吧,假设d=gcd(a,b). 那么x=x0+b/d*t; y=y0-a/d*t;其中t为任意常整数。

【这个是怎么推导出来的,说实话我也不知道,就先这么记着吧!】

 

 

现在得到了一组可行解,但是如何得到通解呢?

(x0,y0)代入ax+by=c,则有

a*(x0)+b*(y0)=c

通过拆添项,可有:

a*(x0+1*b)+b*(y0-1*a)=c

a*(x0+2*b)+b*(y0-2*a)=c

a*(x0+3*b)+b*(y0-3*a)=c

……

a*(x0+k*b)+b*(y0-k*a)=c  (kZ)

至此,我们得到了通解的方程

x=x0+k*b

y=y0-k*a  (kZ)

这样,所有满足ax+by=c的可行解都可求出。

【充分性易证,代入即可验证。而必要性较难证】。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值