介绍最大公因数和最小公约数(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
相关推荐
yexuhgu1 分钟前
如何在 JavaScript 循环中动态构建 HTML 字符串
jvm·数据库·python
思麟呀2 分钟前
在C++基础上理解CSharp-1
开发语言·c++·c#
wang3zc3 分钟前
使用BERTopic对名言数据集进行批量主题建模的完整实践指南
jvm·数据库·python
码界筑梦坊5 分钟前
361-基于Python的空气质量气候数据分析预测系统
python·信息可视化·数据分析·flask·vue·毕业设计
一念春风7 分钟前
QwenPaw(替代小龙虾)大模型
开发语言·php
m0_609160498 分钟前
Go语言如何做协程调度_Go语言协程调度原理教程【实用】
jvm·数据库·python
小短腿的代码世界13 分钟前
Qt状态机框架深度解析:从状态图到事件驱动闭环
开发语言·qt
2301_8125396713 分钟前
golang如何实现全量数据迁移_golang全量数据迁移实现详解
jvm·数据库·python
小陈的进阶之路18 分钟前
安集商城接口自动化项目架构介绍
python·自动化·pytest
zhaoyong22219 分钟前
uni-app怎么获取短信验证码 uni-app接入短信平台流程【实战】
jvm·数据库·python