从品牌网站建设到网络营销策划,从策略到执行的一站式服务
# 辗转相除法求最大公约数
天峨ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:18982081108(备注:SSL证书合作)期待与您的合作!
def gcd(a, b):
if a b:
a, b = b, a
while a % b != 0:
a, b = b, a % b
return b
gcd(21,49)
程序缩进如图所示
图中两个函数等效,A 使用经典条件分支结构,B 使用条件表达式
代码 A 和 B 等效
# A
def gcd(a, b):
if a == 0:
return b
else:
return gcd(b % a, a)
# B
def gcd(a, b):
return b if a == 0 else gcd(b % a, a)
运行结果
最后的输出语句已经限定了函数名是gcd
函数里的算法是求最大公约数的辗转相除法。辗转相除法是一个循环处理过程,所以第二个是while
同理,最后return的应该是n
def gcd(m,n):
r=m%n
while r:
m=n
n=r
r=m%n
else:
return n
python求最大公约数和最小公倍数
定义一个函数
def hcf(x, y):
该函数返回两个数的最大公约数
# 获取最小值
if x y:
smaller = y
else:
smaller = x
for i in range(1,smaller + 1):
if((x % i == 0) and (y % i == 0)):
hcf = i
return hcf
# 用户输入两个数字
num1 = int(input("输入第一个数字: "))
num2 = int(input("输入第二个数字: "))
print( num1,"和", num2,"的最大公约数为", hcf(num1, num2))
求两个数的最小公倍数的算法有很多种,效率最高的一种是先计算出它们的最大公约数。
采用辗转相除法,可以求出两个正整数的最大公约数。先保存a和b的数值的副本,求出a÷b的余数,如果不等于零,就令a=b,b等于这一次的余数。
重复做上述的除法零,直到余数为0的时候,B的值就是一开始两个数的最大公约数。这时初始的两数乘积除以最大公约数就是两个数的最小公倍数。
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图