#A1044. 辗转相除法
辗转相除法
题目描述
辗转相除法,也称欧几里得算法,是求最大公约数的算法。辗转相除法首次出现于欧几里得的《几何原本》(第VII卷,命题i和ii)中,而在中国则可以追溯至东汉出现的《九章算术》。
两个整数的最大公约数(Greatest Common Divisor)是能够同时整除它们的最大的正整数,缩写为gcd。辗转相除法基于如下原理:
定理:两个整数的最大公约数等于其中较小的那个数和两数相除余数的最大公约数.
用数学语言表示就是:%
在这个过程中,较大的数缩小了,所以继续进行同样的计算可以不断缩小这两个数直至其中一个变成零。这时,所剩下的还没有变成零的数就是两数的最大公约数。
例如,计算和的最大公约数的过程如下:
(1)让除以得到余数:,所以
(2)让除以得到余数:,所以
(3)让除以得到余数:,所以
(4)此时较小的数已经是,所以.
所以
输入格式
一行2个自然数 和,保证。
输出格式
只有一行一个整数,表示和的最大公因数
36 24
12
2520 2160
360
统计
相关
在以下作业中: