美文网首页
欧几里德与扩展欧几里德算法

欧几里德与扩展欧几里德算法

作者: tdeblog | 来源:发表于2016-06-27 16:46 被阅读0次

欧几里德算法
欧几里德算法又称辗转相除法,用于计算两个整数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 , d |r ,但是a = kb +r
  因此d也是(a,b)的公约数
  因此(a,b)和(b,a mod b)的公约数是一样的,其最大公约数也必然相等,得证

int gcd(int a,int b)
{
    if(b==0)
        return a;
    return 
        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,所以递归可以结束。

int exgcd(int a,int b,int &x,int &y)
{
    if(b==0)
    {
        x=1;
        y=0;
        return a;
    }
    int r=exgcd(b,a%b,x,y);
    int t=x;
    x=y;
    y=t-a/b*y;
    return r;
}

相关文章

  • 最大公约数

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

  • 欧几里德与扩展欧几里德算法

    欧几里德算法欧几里德算法又称辗转相除法,用于计算两个整数a,b的最大公约数。基本算法:设a=qb+r,其中a,b,...

  • 扩展欧几里德算法

    扩展欧几里得算法(英语:Extended Euclidean algorithm)是欧几里得算法(又叫辗转相除法)...

  • 扩展欧几里德算法

    扩展欧几里德算法用来在已知和的情况下,求等式的一组可行解,该算法思路如下: 若,则有,是一组可行解 若,则设递归求...

  • 扩展欧几里德

    扩展欧几里得 求解不定方程 ax+by=gcd(a, b) 的整数解 对于方程 ax+by=c, 如果 gcd(a...

  • 欧几里德算法

    The Euclidean Algorithm欧几里德算法(又称辗转相除法)是一种用于快速寻找两个整数的最大公约数...

  • 欧几里德算法

    需求: 计算最大公因数。两个整数德最大公因数(Gcd)是同时整除二者的最大整数。 算法通过连续计算余数直到余数是0...

  • 算法学习(1)----扩展欧几里得算法

    欧几里德算法 欧几里德算法又称辗转相除法,用于计算两个整数a,b的最大公约数。其计算原理依赖于下面的定理: gcd...

  • 欧几里德算法原理

    欧几里德算法: 实在不好意思 我验算的同时没有统一标识 希望大家能包含

  • 快速排序

    快速排序 原理:欧几里德算法快排的概念:分而治之 代码:

网友评论

      本文标题:欧几里德与扩展欧几里德算法

      本文链接:https://www.haomeiwen.com/subject/prwzdttx.html