介绍最大公因数和最小公约数(Python)

最大公因数(GCD)

最大公因数是指两个或多个整数共有约数中最大的一个。在Python中,计算最大公因数可以使用math模块中的gcd函数(Python 3.5+)。对于更早版本或自定义实现,可以使用欧几里得算法。

使用math.gcd函数:

python 复制代码
import math
a = 48
b = 18
gcd = math.gcd(a, b)
print(gcd)  # 输出:6

欧几里得算法实现:

python 复制代码
def gcd(a, b):
    while b:
        a, b = b, a % b
    return a

print(gcd(48, 18))  # 输出:6

最小公倍数(LCM)

最小公倍数是指两个或多个整数公有的倍数中最小的一个。计算最小公倍数通常基于最大公因数,利用公式: \\text{LCM}(a, b) = \\frac{\|a \\times b\|}{\\text{GCD}(a, b)}

使用math.lcm函数(Python 3.9+):

python 复制代码
import math
a = 12
b = 15
lcm = math.lcm(a, b)
print(lcm)  # 输出:60

自定义实现:

python 复制代码
def lcm(a, b):
    return abs(a * b) // gcd(a, b) if a and b else 0

print(lcm(12, 15))  # 输出:60

多个数的GCD和LCM

对于多个数,可以迭代计算。例如,计算列表[12, 15, 18]的GCD和LCM:

多个数的GCD:

python 复制代码
from functools import reduce
import math

numbers = [12, 15, 18]
gcd_result = reduce(math.gcd, numbers)
print(gcd_result)  # 输出:3

多个数的LCM:

python 复制代码
def lcm_multiple(*args):
    return reduce(lambda x, y: x * y // math.gcd(x, y), args)

print(lcm_multiple(12, 15, 18))  # 输出:180
相关推荐
Warson_L2 小时前
Python `Annotated` 与 LangGraph Reducer 学习笔记
python
韩师傅2 小时前
海天线算法的前世今生
python·计算机视觉
韩师傅2 小时前
当你的甲方设备过烂,要如何快速出效果?
python·计算机视觉
Warson_L2 小时前
LangGraph的MessageState and HumanMessage
python
韩师傅2 小时前
当你的甲方吐槽天空不够蓝,你应该如何应对
python·计算机视觉
Warson_L3 小时前
python的类&继承
python
Warson_L3 小时前
类型标注/type annotation
python
ThreeS5 小时前
手搓MiniVLA全实战教程-一步一步用pytorch解释原理与思路
人工智能·python
金銀銅鐵7 小时前
[Python] 模 n 乘法的逆元计算器
python·数学·游戏