详解扩展欧几里得算法(扩展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 ...
随机推荐
- Cocos2d-x.3.0开发环境搭建之—— 极简式环境搭建
配置:win7 + VS2012 + Cocos2d-x.3.0 + Cocos Studio v1.4.0.1 使用此法可以方便的创建Cocos2d-x项目.如果需要运行Cocos2d-x引擎自带的 ...
- MongoDB学习笔记(五、MongoDB存储引擎与索引)
目录: mongoDB存储引擎 mongoDB索引 索引的属性 MongoDB查询优化 mongoDB存储引擎: 目前mongoDB的存储引擎分为三种: 1.WiredTiger存储引擎: a.Con ...
- log4j日志打印的配置文件简单使用
log4j.properties #将等级为DEBUG的日志信息输出到console和file这两个目的地,console和file的定义在下面的代码 log4j.rootLogger=DEBUG,c ...
- 2017 经典的CVPR 关于ImageCaptioning论文
1. SCA-CNN: Spatial and Channel-wise Attention in Convolutional Networks for Image Captioning ...
- ajax配置项中的type与method
1. jQuery中ajax配置项中的使用type与method的区别本质上两个配置项是没有区别的,区别在于两者出现的时间不同,type对于目前jQuery的版本全部兼容,也就是说$.ajax({ t ...
- dotnet core 调用electron来开发UI的探索
先上仓库地址 https://github.com/lightszero/webwindow.netcore dotnet core 很喜欢,问题dotnet core 不包含GUI,经过一些尝试,觉 ...
- laravel5+ElasticSearch+go-mysql-elasticsearch MySQL数据实时导入(mac)
1. ElasticSearch安装 直接使用brew install elasticsearch 安装最新版本的es,基本没有障碍. 2.Laravel5 框架添加elasticsearch支持 在 ...
- Linux平台安装python的psutil包
在Linux平台下,pip install psutil 安装python psutil包,出现下面的错误: psutil/_psutil_common.c:9:20: fatal error: Py ...
- PHP收集一些常用函数与好用的自定义函数
.自定义打印函数P //自定义打印function pp($data,$exit=0){// 定义样式 $str='<pre style="display: block;padding ...
- Vue 从入门到进阶之路(十四)
之前的文章我们对 vue 的基础用法已经有了很直观的认识,本章我们来看一下 vue 中的生命周期函数. 上图为 Vue官方为我们提供的完整的生命周期函数的流程图,下面的案例我们只是走了部分情况流程,但 ...