`
shazhifeng
  • 浏览: 125153 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

欧几里德算法的简单描述以及C++与Java的各自实现(源代码)

阅读更多

欧几里德算法描述:
欧几里德算法又称辗转相除法,用于计算两个整数a,b的最大公约数。其计算原理依赖于下面的定理:
定理:gcd(a,b) = gcd(b,a mod 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)的公约数是一样的,其最大公约数也必然相等,得证

下面是该算法的C++实现:

void swap(int & a, int & b){
    int c = a;
    a = b;
    b = c;
} 

int gcd(int a,int b){
    if(0 == a ){
        return b;
    } 

    if( 0 == b){
        return a;
    } 

    if(a > b){
        swap(a,b);
    } 

    int c;
    for(c = a % b ; c > 0 ; c = a % b){
        a = b;
        b = c;
    } 

    return b;
}

 

下面是Java实现代码:

publicclass MaxFeed{
    publicint getnum(int m,int n){
        int r=getleave(m,n);
        while(r!=0){
            int[] s=swapnum(m,n,r);
            m=s[0];
            n=s[1];
            r=getleave(m,n);
        }
        return n;
    }
    /**
     *@paramm
     *@paramn
     *@return
     */
    privateint getleave(int m,int n){
        int r=m%n;
        return r;
    }
    /**
     *<p>comments:交换
     *          </p>
     *@paramm
     *@paramn
     *@paramr
     *@return
     */
    privateint[] swapnum(int m,int n,int r){
        m=n;
        n=r;
        int[] s=newint[2];
        s[0]=m;
        s[1]=n;
        return s;
    }
    /**
     *<p>comments:测试用例
     *          </p>
     *@paramargs
     */
    publicstaticvoid main(String[] args){
        MaxFeed maxFeed=new MaxFeed();
        int r=maxFeed.getnum(96,27);
        System.out.println("***********************************\n\n\n");
        System.out.println("                 "+r);
        System.out.println("***********************************");
    }

 

分享到:
评论

相关推荐

    扩展欧几里德算法c++代码

    实现扩展欧几里得算法的代码,很简单,能够成功运行。

    欧几里德算法求最大公约数——C++代码

    尽管代码可能简单,但它是理解算法和基本C++编程的好起点。通过这种方式,初学者可以逐步建立起对编程和算法设计的掌握,而不仅仅是完成作业。当然,无论作业是否被仔细检查,掌握知识才是最重要的。

    欧几里德算法和扩展欧几里德算法。用C和C++实现。.zip

    欧几里德算法和扩展欧几里德算法。用C和C++实现。.zip

    12--[scratch欧几里德算法].zip源码scratch2.0 3.0编程项目源文件源码案例素材源代码

    12--[scratch欧几里德算法].zip源码scratch2.0 3.0编程项目源文件源码案例素材源代码12--[scratch欧几里德算法].zip源码scratch2.0 3.0编程项目源文件源码案例素材源代码12--[scratch欧几里德算法].zip源码scratch...

    欧几里德算法-少儿编程scratch项目源代码文件案例素材.zip

    在这个"欧几里德算法.sb2"文件中,包含了完整的Scratch项目源代码,孩子们可以通过分析和修改这些代码,来理解欧几里德算法的工作原理。 欧几里德算法的基本思想是:对于任意两个正整数a和b(a&gt;b),它们的最大公...

    acm 扩展欧几里德算法与中国剩余定理ppt教程 acmer教程系列

    本文详细介绍了扩展欧几里德算法和中国剩余定理的原理、实现代码及应用,包括扩展欧几里德算法的定义、原理、实现代码、中国剩余定理的定义、原理、实现代码等。 扩展欧几里德算法是指在已知 a, b的情况下,求解一...

    欧几里德算法和扩展欧几里德算法.doc

    欧几里德算法和扩展欧几里德算法是数论中两个重要的算法,用于计算两个整数的最大公约数和模乘法逆元。 一、欧几里德算法 欧几里德算法是一种计算两个整数最大公约数的算法,依赖于以下定理:gcd(a,b) = gcd(b,a ...

    扩展欧几里德算法---

    **扩展欧几里德算法详解** 在数学领域,特别是数论中,欧几里德算法是求解两个正整数最大公约数(GCD)的一种高效方法。它基于这样一个基本事实:两个正整数a和b(假设a&gt;b)的最大公约数与b和a除以b的余数a mod b的...

    算法文档无代码欧几里德算法的应用

    在本例中,文档标题提到“欧几里德算法的应用”,而描述中提到“算法文档无代码欧几里德算法的应用提取方式是百度网盘分享地址”,表明了文档中可能详述了欧几里得算法在不同领域的应用实例,同时说明了获取该文档的...

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

    欧几里德算法和扩展欧几里德算法--透彻理解 模P乘法逆元 对于整数a、p,如果存在整数b,满足a×b mod p =1,则说,b是a的模p乘法逆元。

    自己编的扩展欧几里德算法

    在C++中,我们可以这样实现扩展欧几里德算法: ```cpp #include std::pair, int&gt; extendedEuclidean(int a, int b) { if (b == 0) return std::make_pair(1, 0); std::pair, int&gt; p = extendedEuclidean(b, a %...

    扩展欧几里德算法

    在数论和计算机科学中,尤其是在加密算法、线性同余方程的求解以及模逆运算等领域,扩展欧几里德算法有着广泛的应用。 **一、欧几里德算法基础** 欧几里德算法,也称为辗转相除法,是公元前3世纪由古希腊数学家...

    扩展的欧几里德算法.doc

    欧几里德算法是计算两个整数最大公约数(Greatest Common Divisor, GCD)的经典算法,由古希腊数学家欧几里得提出。它的基本思想是利用数学归纳法,通过不断用较大的数除以较小的数并取余,直到其中一个数变为0,...

    欧几里德乘法逆元算法实现

    描述中的"自己实现,不过借鉴了网上的发达发达省份打发打发"可能意味着作者在编写代码时参考了其他资源,这是很常见的编程实践。实现这种算法时,要注意处理边界条件,比如当a和b有一个为0时,以及避免除以0的错误。...

    欧几里德算法和仿射密码

    1. **`int Extendgcd(int d, int f)`**:这是一个扩展欧几里德算法的实现,用于求解两个整数的最大公约数以及模逆元。当gcd不等于1时,表明a和26互质条件不成立,不能作为有效密钥使用。 2. **`void Affine()`**:...

    欧几里德算法

    欧几里德算法是一种简单而强大的工具,不仅在纯数学中有广泛应用,在实际工程问题解决中也同样重要。通过对算法的理解和掌握,可以更好地应用到不同的场景中,无论是学术研究还是软件开发等领域。

    欧几里德C语言算法

    欧几里德C语言算法

    MFC 欧几里德算法

    扩展欧几里德算法的C++实现如下: ```cpp std::pair, int&gt; extendedEuclidean(int a, int b) { int x = 1, y = 0, u = 0, v = 1; while (b != 0) { int q = a / b, r = a % b; a = b; b = r; x = u; y = v; u...

    欧几里德算法 欧几里德 ,VC VS c VC

    适合初学者适合初学者 欧几里德算法 适合初学者适合初学者 欧几里德算法 适合初学者适合初学者 欧几里德算法

    关于扩展欧几里德算法的报告

    ### 扩展欧几里德算法与青蛙会面问题 #### 一、引言 本文旨在探讨如何利用扩展欧几里德算法解决一个有趣而实际的问题——两只青蛙能否在同一条纬度线上相遇。该问题不仅涉及基本的数学概念,如数轴、距离和速度,...

Global site tag (gtag.js) - Google Analytics