扩展欧几里得

扩展欧几里得

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

欧几里德算法又称辗转相除法,用于计算两个整数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)

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • VSCode汉化_vscode汉化插件

    VSCode汉化_vscode汉化插件1.打开VSCode点击箭头指示地方在搜索框中输入chinese然后安装中文简体2.按住Ctrl+shift+p选择配置显示语言然后会看见下面的样子添加"locale&qu

  • 系统引导管理 之 系统引导管理器GRUB,为初学者指南

    系统引导管理 之 系统引导管理器GRUB,为初学者指南

  • 钉钉自定义机器人发送消息到钉钉群[通俗易懂]

    钉钉自定义机器人发送消息到钉钉群[通俗易懂]1、新建机器人2、生成密钥packagecom.epmet.commons.tools.utils;/***描述一下**@authorxxxx*@date2020/6/2417:42*/importjavax.crypto.Mac;importjavax.crypto.spec.SecretKeySpec;importorg.apache.commons.codec.binary.Base64;importjava.net.URLEncod

  • Elastic:开发者上手指南

    Elastic:开发者上手指南您们好,我是Elastic的刘晓国。如果大家想开始学习Elastic的话,那么这里将是你理想的学习园地。在我的博客几乎涵盖了你想学习的许多方面。在这里,我来讲述一下作为一个菜鸟该如何阅读我的这些博客文章。我们可以按照如下的步骤来学习:1)Elasticsearch简介:对Elasticsearch做了一个简单的介绍2)Elasticsearch中的一些重要概念:cluster,n…

  • vue解决跨域_java跨域解决方案

    vue解决跨域_java跨域解决方案现阶段跨域方式有很多种,但是基本思想只有两种:绕过同源策略:历史遗留的产物,虽然思想很好,但是局限性太大(仅支持、因为数据是在中,所以携带数据小)。:通过反向代理绕过去,这是很完美的解决方案,加上会给服务器增加一点压力,不过这点压力问题并不大[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ddoEgRFd-1656482203293)(https://juejin.cn/)][外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4M4avsX0-1

  • elasticsearch 入门安装

    elasticsearch 入门安装

发表回复

您的电子邮箱地址不会被公开。

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