Python中的gcd()函数用于计算两个整数的最大公约数(Greatest Common Divisor,GCD)。这个函数的实现原理基于欧几里得算法(Euclidean Algorithm)。
欧几里得算法是一种非常古老的算法,用于计算两个整数的最大公约数。算法的基本思想是:两个整数的最大公约数等于其中较小的数和两数的差的最大公约数。例如,gcd(48, 18) = gcd(18, 30) = gcd(18, 12) = 6。
在Python中,gcd()函数的实现可以使用math模块中的gcd()函数,如下所示:
import math a = 48 b = 18 result = math.gcd(a, b) print("The GCD of", a, "and", b, "is", result)
输出结果为:
The GCD of 48 and 18 is 6
此外,你还可以使用递归方式自定义gcd()函数,如下所示:
def gcd(a, b): if b == 0: return a else: return gcd(b, a % b) a = 48 b = 18 result = gcd(a, b) print("The GCD of", a, "and", b, "is", result)
输出结果与上面相同:
The GCD of 48 and 18 is 6