博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
世界上最早的算法:辗转相除法(求两个自然数最大公约数)
阅读量:6090 次
发布时间:2019-06-20

本文共 1215 字,大约阅读时间需要 4 分钟。

   在数学界,辗转相除法,又称欧几里得算法,被认为是世界上最早的算法(公元前300年),该算法用于求两个最大公约数的算法。辗转相除法首次出现于欧几里得的《几何原本》(第VII卷,命题yⅠ和Ⅱ)中,而在中国则可以追溯至东汉出现的《九章算术》。

   两个自然数的最大公约数是能够同时整除它们的最大的正整数。辗转相除法基于如下原理:两个整数的最大公约数等于其中较小的数和两数的相除余数的最大公约 数。例如,1254和390的最大公约数是6(1254 = 6 × 209;390 = 6 × 65);用这两个数推导最大公约数的过程如下:

1254 % 390 = 84

390 % 84 = 54

84 % 54 = 30

54 % 30 = 24

30 % 24 = 6

所以这两个数的最大公约数是6,这很明显是递归算法

这个算法的证明如下:

    设两数为a、b(b<a),用gcd(a,b)表示a,b的最大公约数,r=a mod b 为a除以b以后的余数,k为a除以b的商。辗转相除法即是要证明gcd(a,b)=gcd(b,r)。

第一步:令c=gcd(a,b),则设a=mc,b=nc

第二步:根据前提可知r =a-kb=mc-knc=(m-kn)c

第三步:根据第二步结果可知c也是r的因数

第四步:可以断定m-kn与n互素【否则,可设m-kn=xd,n=yd,(d>1),则m=kn+xd=kyd+xd=(ky+x)d,则a=mc=(ky+x)dc,b=nc=ycd,故a与b最大公约数成为cd,而非c,与前面结论矛盾】

从而可知gcd(b,r)=c,继而gcd(a,b)=gcd(b,r)。

PS:这个结论是根据第二步r =(m-kn)c,第一步b =nc   将r带入gcd(b,r),得到gcd(nc, (m-kn)c),所以只有n和m-kn互为素数,b和r的最大公约数才为c

下面给出Java的实现

public class GCD{    public static int getGCD(int a, int b)    {        if(a < 0 || b < 0)            return -1;        if(a < b)        {            int c = b;            b = a;            a = c;        }        int c = a % b;        if(c == 0)            return b;        else            return getGCD(b, c);    }         public static void main(String[] args)    {       System.out.println(getGCD(1254, 390));    }}

转载地址:http://pulwa.baihongyu.com/

你可能感兴趣的文章
Vmware view 5.0 POC环境搭建参考v1.0
查看>>
编程小知识点范例-1
查看>>
同一Tomcat 多个端口部署不同的项目
查看>>
mysql启用审计功能
查看>>
6月第2周安全回顾 合法网站提供恶意软件 智能手机威胁大
查看>>
2012 oracle数据库会议总结
查看>>
5.VMware View 4.6安装与部署-安装view agent与模版
查看>>
【Silverlight】Bing Maps学习系列(五):绘制多边形(Polygon)图形
查看>>
“单向网闸”技术介绍-网络隔离的新型产品
查看>>
Android2.0之后读取联系人——ContactsContract
查看>>
C/C++中的近指令、远指针和巨指针
查看>>
随机生成50个字段的elasticsearch的测试程序输入
查看>>
android下创建文件夹和修改其权限的方法
查看>>
第三篇:属性_第二节:控件属性在页面及源码中的表示方式
查看>>
数据结构与内存管理策略(上)
查看>>
python 23 种 设计模式
查看>>
java基础面试题
查看>>
如何使用DXUT框架
查看>>
六、传递、返回复杂类型的对象
查看>>
android:TabWidget/TabHost
查看>>