详解扩展欧几里得算法(扩展GCD)
浅谈扩展欧几里得(扩展GCD)算法
本篇随笔讲解信息学奥林匹克竞赛中数论部分的扩展欧几里得算法。为了更好的阅读本篇随笔,读者最好拥有不低于初中二年级(这是经过慎重考虑所评定的等级)的数学素养。并且已经学会了学习这个算法的前置知识:欧几里得算法。
对于对欧几里得算法还有知识模糊的读者,请不要担心,这里为你准备了前导知识讲解,请移步至本蒟蒻的另两篇博客:
裴蜀定理
裴蜀定理的概念及证明
因为翻译版本的不同,这个定理可能还会被叫做贝祖定理、\(B\acute{e}zout\)定理等。
裴蜀定理是这样被描述的:
\]
满足:
\]
文字描述是这样的:对于任意的整数\(a,b\),都存在一对整数\(x,y\),使得\(ax+by=\gcd(a,b)\)成立。
证明:
来看欧几里得算法求解过程的这个函数:
int gcd(int a,int b)
{
return b?gcd(b,a%b):a;
}
可以看出,这是一个递归求解的函数。在函数递归到最后的时候,存在\(b=0\),不管\(a\)是什么,这时显然有一对整数\(x=1,y=0\)来使得:
\]
(ps:0和任何数的最大公约数都等于原数,可以从最大公约数和约数的定义得知)
那么,我们通过这个递归的实现过程来进行回溯的模拟。当\(b>0\),则程序还可以继续往下走:\(\gcd(b,a\%b)=\gcd(a,b)\)。这时假设存在一对整数\(x,y\),使得其一定会满足\(b\times x+(a\%b)\times y=\gcd(b,a\%b)\), 因为\(a\%b=a-b\lfloor a/b\rfloor\),所以有以下的推导:
\]
这个时候令\(x^{'}=y,y^{'}=x-\lfloor a/b\rfloor y\),再结合一开始的原式子,就得出:
\]
因为欧几里得算法的实现是递归的,而我们已经推出其中一个递归过程的实现,那么其他的递归过程就可以借助数学归纳法,一层层地向上推,必然会得出最终结论。
证毕。
裴蜀定理的应用
裴蜀定理:
\]
那么可以推出:如果一个数\(m\)满足:\(ax+by=m\),那么这个\(m\)一定是\(\gcd(a,b)\)的倍数。
那么对于一个经典方程\(ax+by=1\),利用裴蜀定理,我们有:\(\gcd(a,b)=1\),即\(a,b\)一定互质。
扩展欧几里得算法
在介绍扩展欧几里得算法之前,我想首先介绍它的应用:
1、求解不定方程
2、求解模的逆元
3、求解线性同余方程
为什么它能应用到这几个方面呢?回到裴蜀定理:
\]
对于这个不定方程,如果存在一组合法的解\((x,y)\),那么一定会有\(\gcd(a,b)|m\),即\(m\)是\(\gcd(a,b)\)的倍数。那么现在我不仅想知道到底有没有解,而是想知道在有解的情况下,这个解到底是多少。
这就是求解不定方程的过程。这个解决的算法就叫做扩展欧几里得算法。
可以发现,我们求解不定方程其实就是要求解一组合法的\((x,y)\),那么根据裴蜀定理的证明(基于欧几里得算法,采用递归的数学归纳),可以发现\(x,y\)的互相推导的关系。
这种采取递归来求解\(x,y\)的方法就叫做扩展欧几里得算法。
扩展欧几里得算法的实现:
先放板子:
int exgcd(int a,int b,int &x,int &y)
{
if(b==0)
{
x=1,y=0;
return a;
}
int d=exgcd(b,a%b,x,y);
int k=x;
x=y;
y=k-a/b*y;
return d;
}
扩展欧几里得算法的实现基于裴蜀定理的证明。实质上相当于在做欧几里得算法(普通GCD)的时候对不定方程\(ax+by=m\)的\(x,y\)也做了更改。所以经过扩展欧几里得算法处理过的\(x,y\)就已经是一组合法的可行解了。
这里需要注意一个细节,因为扩展GCD需要对\(x,y\)本身进行修改,所以需要在传参数的时候加取址符,这样能保证被修改。
详解扩展欧几里得算法(扩展GCD)的更多相关文章
- 初等数论-Base-2(扩展欧几里得算法,同余,线性同余方程,(附:裴蜀定理的证明))
我们接着上面的欧几里得算法说 扩展欧几里得算法 扩展欧几里德算法是用来在已知a, b求解一组x,y,使它们满足贝祖等式\(^①\): ax+by = gcd(a, b) =d(解一定存在,根据数论中的 ...
- 扩展欧几里得算法详解(exgcd)
一.前言 本博客适合已经学会欧几里得算法的人食用~~~ 二.扩展欧几里得算法 为了更好的理解扩展欧几里得算法,首先你要知道一个叫做贝祖定理的玄学定理: 即如果a.b是整数,那么一定存在整数x.y使得$ ...
- 模板——扩展欧几里得算法(求ax+by=gcd的解)
Bryce1010模板 /**** *扩展欧几里得算法 *返回d=gcd(a,b),和对应等式ax+by=d中的x,y */ long long extend_gcd(long long a,long ...
- 【learning】 扩展欧几里得算法(扩展gcd)和乘法逆元
有这样的问题: 给你两个整数数$(a,b)$,问你整数$x$和$y$分别取多少时,有$ax+by=gcd(x,y)$,其中$gcd(x,y)$表示$x$和$y$的最大公约数. 数据范围$a,b≤10^ ...
- gcd(欧几里得算法)与exgcd(扩展欧几里得算法)
欧几里得算法: 1.定义:gcd的意思是最大公约数,通常用扩展欧几里得算法求 原理:gcd(a, b)=gcd(b, a%b) 2.证明: 令d=gcd(a, b) => a=m*d,b=n ...
- 扩展欧几里得算法(extgcd)
相信大家对欧几里得算法,即辗转相除法不陌生吧. 代码如下: int gcd(int a, int b){ return !b ? gcd(b, a % b) : a; } 而扩展欧几里得算法,顾名思义 ...
- 欧几里得算法与扩展欧几里得算法_C++
先感谢参考文献:http://www.cnblogs.com/frog112111/archive/2012/08/19/2646012.html 注:以下讨论的数均为整数 一.欧几里得算法(重点是证 ...
- vijos1009:扩展欧几里得算法
1009:数论 扩展欧几里得算法 其实自己对扩展欧几里得算法一直很不熟悉...应该是因为之前不太理解的缘故吧这次再次思考,回看了某位大神的推导以及某位大神的模板应该算是有所领悟了 首先根据题意:L1= ...
- ****ural 1141. RSA Attack(RSA加密,扩展欧几里得算法)
1141. RSA Attack Time limit: 1.0 secondMemory limit: 64 MB The RSA problem is the following: given a ...
随机推荐
- 什么是 AQS?简单说一下 ReentrantLock 的原理?
AQS 简介 java的内置锁一直都是备受争议的,在JDK 1.6之前,synchronized这个重量级锁其性能一直都是较为低下,虽然在1.6后,进行大量的锁优化策略,但是与Lock相比synchr ...
- AES加密原理和AOE工程实践
在AI业务的开发的过程中,我们常常需要对模型文件进行加密.我们从以下几个方面来说一说AES的加密原理以及AOE里的工程实践. 常见的加密算法 AOE对模型加密需求的思考 AES的加密原理 AOE工程实 ...
- 2.Ansible Playbook剧本
1.playbook?playbook翻译过来就是"剧本",那playbook组成如下 play: 定义的是主机的角色 task: 定义的是具体执行的任务 playbook: 由一 ...
- AVAssetDownloadURLSession
NSURLSession 的子类,用于支持创建和执行资产下载任务的URL会话,主要是用来下载HLS资源内容的 AVAssetDownloadURLSession reference https://d ...
- You don't have permission to access / on this server,Forbidden
wampserver配置虚拟主机Forbidden,apache You don't have permission to access 找到httpd.conf文件(通常在安装apache的conf ...
- 附007.Kubernetes ABAC授权
一 ABAC 1.1 ABAC授权 基于属性的访问控制(ABAC)定义了访问控制范例,通过使用将属性组合在一起的策略向用户授予访问权限. 使用--authorization-policy-file=S ...
- VM虚拟机安装无法将值写入注册表.....请确认你是否有足够的权限访问该注册表项,或者与技术支持人员联系。
解决方法: 关掉360安全卫士等软件再安装
- 用POI 3.17 导出EXECL
代码参考 https://www.cnblogs.com/bmbm/archive/2011/12/08/2342261.html 效果 导入jar包 <dependency> <g ...
- uni-app中onLoad不起作用
最近开始使用uni-app,坑还是很多的 今天在使用onLoad是发现,页面上的onLoad方法是可以起作用的,但是组件中的onLoad方法并没有起作用 后来经过一番尝试后还是不行,看文档发现uni- ...
- 资深程序员对于Python各个方向的面试经验分享,非常给力!
之前早有前辈们说过,"裸辞一时爽,一直裸辞一直爽",这话一点不假,裸辞你要面临没有收入来源,但是每天眼睁睁看着各种花销不断支出的煎熬,我主要是觉得一边在上家公司工作一边去下家面试可 ...