扩展欧几里得

扩展欧几里得

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

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

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

递归代码

__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,所以递归能够结束。

递归代码:

__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的最大公约数)有整数解(x1,y1);则ax+by=c(c是g的倍数)有整数解(cx1/g,cy1/g)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • requests请求时,遇到的Accept-Encoding问题

    requests请求时,遇到的Accept-Encoding问题在使用requests请求链接的时候,发现请求得到的内容总是一堆乱码:此时请求的headers里的Accept-Encoding是这样写的:headers={‘Accept-Encoding’:’gzip,deflate’,’User-Agent’:str(‘Mozilla/5.0(WindowsNT10.0;Win64;x64;rv:81.0)Gecko/20100101Firefox/81.0’)}查看目标

    2022年7月15日
    30
  • 小程序的各种弹窗(微信小程序弹窗怎么关)

    //test.jsPage({popSuccessTest:function(){wx.showToast({title:’成功提示弹窗’,icon:”,//默认值是success,就算没有icon这个值,就算有其他值最终也显示successduration:2000,//停留时间})}…

    2022年4月18日
    263
  • VC++常用功能开发「建议收藏」

    VC++常用功能开发「建议收藏」系列文章目录第一章:VC++ini配置文件封装类源代码第二章:VC++实现二维码(显示+保存图片)功能源代码第三章:VC++调节系统音量(与任务栏音量同步)源代码提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录系列文章目录 前言 一、pandas是什么? 二、使用步骤 1.引入库 2.读入数据 总结前言提示:这里可以添加本文要记录的大概内容:例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启..

    2022年5月2日
    31
  • 网络编程01_01是什么

    网络编程01_01是什么网络编程1.1概述网络编程的目的:信息传递,数据交换,通信。实现网络的条件:如何准确定位网络上的一台主机?IP地址+端口号定位到这台计算机上的某个资源找到了这个主机,如何传输数据?——硬件传输介质网络通信的规则:协议——UDP,TCP​ TCP/IP参考模型[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aBe6VKUl-1639203769386)(…/image/01-16372424176942.png)]Javaweb——网页

    2022年8月9日
    10
  • 【Github教程】史上最全github用法:github入门到精通

    【Github教程】史上最全github用法:github入门到精通

    2021年11月29日
    56
  • CTR预估算法之FM, FFM, DeepFM及实践

    CTR预估算法之FM, FFM, DeepFM及实践目录目录CTR预估综述FactorizationMachines(FM)算法原理代码实现Field-awareFactorizationMachines(FFM)算法原理代码实现DeepFM算法原理代码实现参考文献CTR预估综述点击率(Clickthroughrate)是点击特定链接的用户与查看页面,电子邮…

    2022年6月12日
    41

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号