Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >扩展欧几里得

扩展欧几里得

作者头像
全栈程序员站长
发布于 2022-07-08 11:37:16
发布于 2022-07-08 11:37:16
51200
代码可运行
举报
运行总次数:0
代码可运行

大家好,又见面了,我是全栈君。

欧几里德算法又称辗转相除法,用于计算两个整数a,b的最大公约数。

基本算法:设a=qb+r。当中a,b。q,r都是整数。则gcd(a,b)=gcd(b,r)。即gcd(a,b)=gcd(b,a%b)。

递归代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
__int64 gcd(__int64 a,__int64 b)
{
    return b==0?a:gcd(b,a%b);
}

扩展欧几里得

基本算法:对于不全然为 0 的非负整数 a,b。gcd(a。b)表示 a,b 的最大公约数,

必定存在整数对 x。y ,使得 gcd(a,b)=ax+by。

证明:设 a>b。

1。显然当 b=0。gcd(a,b)=a。此时 x=1。y=0;

2,ab!=0 时。设 ax1+by1=gcd(a,b);

  bx2+(a mod b)y2=gcd(b,a mod b);

  依据朴素的欧几里德原理有 gcd(a,b)=gcd(b,a mod b);

 则:ax1+by1=bx2+(a mod b)y2;

  即:ax1+by1=bx2+(a-(a/b)*b)y2=ay2+bx2-(a/b)*by2;

  依据恒等定理得:x1=y2; y1=x2-(a/b)*y2;

这样我们就得到了求解 x1,y1 的方法:x1。y1 的值基于 x2,y2.

  上面的思想是以递归定义的,由于 gcd 不断的递归求解一定会有个时候 b=0,所以递归能够结束。

递归代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
__int64 exgcd(__int64 a,__int64 b,__int64 &x1,__int64 &y1)
{
    __int64 t,d;
    if(b==0){
        x1=1;
        y1=0;
        return a;
    }
    d=exgcd(b,a%b,x1,y1);
    t=x1;
    x1=y1;
    y1=t-a/b*y1;
    return d;
}

扩展欧几里德算法的应用主要有下面三方面:

(1)求解不定方程。

(2)求解模线性方程(线性同余方程)。

(3)求解模的逆元;

补充定理:

1.设a,b,c为随意整数。若方程ax+by=c的一组整数解为(x0。y0),

则它的随意整数解都能够写成(x0+kb’,y0-ka’),当中a’=a/gcd(a。b),b’=b/gcd(a,b),k为随意整数

2.定理:若ax+by=g。(g=gcd(a,b),即g是a,b的最大公约数)有整数解;则ax+by=c(c是g的倍数)有整数解

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/115950.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年1月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
欧里几德及扩展欧里几德算法
欧几里德算法 欧几里德算法又称辗转相除法,用于计算两个整数a,b的最大公约数。 基本算法:设a=qb+r,其中a,b,q,r都是整数,则gcd(a,b)=gcd(b,r),即gcd(a,b)=gcd(b,a%b)。 第一种证明:       a可以表示成a = kb + r,则r = a mod b   假设d是a,b的一个公约数,则有   d|a, d|b,而r = a - kb,因此d|r   因此d是(b,a mod b)的公约数   假设d 是(b,a mod b)的公约数,则   d | b ,
Angel_Kitty
2018/04/08
9040
The equation-SGU106(扩展欧几里得)
给出 a,b,c,x1,x2,y1,y2,求满足 ax+by+c=0,且 x∈[x1,x2],y∈[y1,y2] 的整数解个数。
Cell
2022/02/25
3600
欧几里得算法(辗转相除法),扩展欧几里得算法,乘法逆元,最小正整数解
欧几里得算法是用来求解两个不全为0的非负整数m和n的最大公约数的一个高效且简单的算法。该算法来自于欧几里得的《几何原本》。数学公式表达如下:
zy010101
2019/05/25
7K0
扩展欧几里得算法
    有两个数 a b,现在,我们要求 a b 的最大公约数,怎么求?枚举他们的因子?不现实,当 a b 很大的时候,枚举显得那么的naïve ,那怎么做?
瑾诺学长
2018/09/21
1.6K0
扩展欧几里得算法
2022_HAUE_计算机学院暑期培训——扩展欧几里得算法
求 100 和18 两个正整数的最大公约数,用欧几里得算法,是这样进行的: 100 / 18 = 5 (余 10) 100%8=10 18 / 10= 1(余8) 18%10=8 10 / 8 = 1(余2) 10%8=2 8 / 2 = 4 (余0) 8%2=0 至此,最大公约数为2 以除数和余数反复做除法运算,当余数为 0 时,取当前算式除数为最大公约数,所以就得出了 100 和 18 的最大公约数2。
浪漫主义狗
2022/09/16
7260
2022_HAUE_计算机学院暑期培训——扩展欧几里得算法
拓展欧几里得算法与应用
即:gcd(a,b)=gcd(b,a%b)欧几里得算法在oi里非常常用,几乎每个数学题都有欧几里得算法——gcd。说白了就是求最大公约数。一行代码搞定:
yzxoi
2022/09/19
2870
详解Winograd变换矩阵生成原理
其实网上已经有不少从数学原理的角度去解说Winograd[1,2,3,4,5,6,10]这个算法的文章了,为什么我还要写这篇文章。
用户7118204
2020/04/07
1.1K0
扩展欧几里德算法
对于不完全为 0 的非负整数 a,b,若gcd(a,b)表示 a,b 的最大公约数,必然存在整数对x,y ,使得 ax+by = gcd(a,b)。
饶文津
2020/06/02
3340
裴蜀定理、扩展欧几里得算法及其证明
裴蜀定理说明了对任何整数a,b和它们的最大公约数d,关于未知数x和y的线性不定方程:若a,b是整数,且gcd(a,b)=d,那么对于任意的整数x,y,ax+by都一定是d的倍数,特别的,一定存在整数x,y使ax+by=d成立。
fishhh
2022/08/31
1.2K0
裴蜀定理、扩展欧几里得算法及其证明
扩展Euclidean算法求乘法逆原理详解与算法实现
mod 1234 (3)计算 gcd(57,93),并找出整数s和t,使得57s+93t=gcd(57,93) (4)求解下列同余方程组
timerring
2022/07/20
9250
扩展Euclidean算法求乘法逆原理详解与算法实现
Romantic HDU - 2669(扩欧模板题)
扩展欧几里德算法——找出一对整数(x,y), 使得ax+by = gcd(a,b)。 注意, 这里的x和y不一定是正数, 也可能是负数或者0。 例如, gcd(6,15)=3,6*3-15*1=3, 其中x=3, y=-1。 这个方程还有其他解, 如x=-2, y=1。
_DIY
2019/09/11
4790
详解Winograd变换矩阵生成原理
其实网上已经有不少从数学原理的角度去解说Winograd[1,2,3,4,5,6,10]这个算法的文章了,为什么我还要写这篇文章。
BBuf
2020/04/01
1.2K0
详解Winograd变换矩阵生成原理
文本首发知乎:https://zhuanlan.zhihu.com/p/87516875
Ldpe2G
2020/01/28
4.5K0
算法基础学习笔记——⑭欧拉函数\快速幂\扩展欧几里得算法\中国剩余定理
在C语言中,可以使用算法来计算欧拉函数(Euler's Totient Function)。欧拉函数,也被称为φ函数,用于计算小于或等于给定数字n的正整数中与n互质的数的个数。
命运之光
2024/03/20
2320
算法基础学习笔记——⑭欧拉函数\快速幂\扩展欧几里得算法\中国剩余定理
扩展欧几里得算法公式推导与Python实现
AI摘要:在数学中,最大公约数(GCD)是两个整数之间的一种重要关系,而贝祖等式则进一步揭示了GCD的深层次应用。本文通过深入浅出的方式,详细推导扩展欧几里得算法的公式,从欧几里得算法开始,一步步揭示其背后的数学原理,并最终实现计算GCD及其贝祖系数的Python代码。无论你是否具备高等数学背景,这篇文章将带你探索如何巧妙地利用扩展欧几里得算法解决实际问题,让你在数学的世界中发现更多的趣味和应用。 扩展欧几里得算法公式推导与Python实现
曈曈too
2024/06/16
2890
从辗转相除法到求逆元,数论算法初体验
辗转相除法又名欧几里得算法,是求最大公约数的一种算法,英文缩写是gcd。所以如果你在大牛的代码或者是书上看到gcd,要注意,这不是某某党,而是指的辗转相除法。
TechFlow-承志
2020/05/29
1.6K0
从辗转相除法到求逆元,数论算法初体验
模逆——拓展欧几里得 - wuuconix's blog
在准备用python实现AES的时候,遇到了求伽罗华域下一个多项式的逆的问题。我发现,我不光把域的知识忘光了,别说多项式的逆了,我连如何用python实现求一个整数的逆都不知道。
wuuconix
2023/03/16
7470
模逆——拓展欧几里得 - wuuconix's blog
Sweet Snippet 系列之 扩展欧几里得算法
扩展欧几里得算法是欧几里得算法(辗转相除法)的扩展,欧几里得算法可以用于求解两个自然数(记为 aaa 和 bbb)的最大公约数,而扩展欧几里得算法不仅可以求出 aaa 和 bbb 的最大公约数,还能同时计算出两个整数 xxx 和 yyy, 使它们满足等式(等式中的 gcd(a,b)gcd(a, b)gcd(a,b) 即表示 aaa 和 bbb 的最大公约数):
用户2615200
2019/07/09
3430
【RSA解密】蓝桥杯第十届省赛A组 扩展欧几里得算法
思路分析:n,d已知的,我们第一步要生成两个质数p,q,这两个质数满足n=pq,且d与(p-1)(q-1)互质,那么我们先找到这两个质数:
Cyril-KI
2022/09/16
4720
【RSA解密】蓝桥杯第十届省赛A组 扩展欧几里得算法
扩展欧几里得算法
欧几里得算法是用来求最大公约数的,gcd(a,b)=gcd(b, a%b),如此递归下去,直到a%b==0,然后返回。
灯珑LoGin
2022/10/31
4020
扩展欧几里得算法
推荐阅读
相关推荐
欧里几德及扩展欧里几德算法
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验