题解 | #求最小公倍数#

求最小公倍数

https://www.nowcoder.com/practice/22948c2cad484e0291350abad86136c3

题目

描述

正整数A和正整数B 的最小公倍数是指 能被A和B整除的最小的正整数值,设计一个算法,求输入A和B的最小公倍数。

数据范围:

1≤a,b≤100000 输入描述: 输入两个正整数A和B。

输出描述: 输出A和B的最小公倍数。

示例1

输入:

5 7

输出:

35

示例2

输入:

2 4

输出:

4

思路

辗转相除法原理:

两个整数的最大公约数等于其中较小的数和两数相除余数的最大公约数。

例如:

欲求252和105的最大公约数;因为 252÷105=2...42,所以这个最大公约数也是42与105的最大公约数(42=21×2)。在这个过程中,较大的数缩小了,所以继续进行同样的计算可以不断缩小这两个数直至余数为零。这时,所剩下的还没有变成零的数就是两数的最大公约数。

我们将上述过程翻译成递归代码,得到如下函数:

def gcd(x,y):
    if x>y:
        x,y = y,x
    if x==0:return y
    return gcd(y%x,x)

注意本题要求是最大公倍数,根据数学定理,a与b的最大公倍数 =(a*b)//a与b的最大公约数,可直接得出答案

代码

a,b = map(int,input().split(" "))

def gcd(x,y):
    if x>y:
        x,y = y,x
    if x==0:return y
    return gcd(y%x,x)

print( (a*b)// gcd(a,b))

#我的实习求职记录##23届找工作求助阵地#
全部评论

相关推荐

我是没经验的毕业生,这啥情况啊会不会是hr在刷kpi
JamesGosli...:字节boss属于是群发了,我都快入职字节了,其他部门还在和我boss打招呼
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-11 11:21
被夸真的超级开心,好可爱的姐姐
码农索隆:老色批们不用脑补了,我把金智妮的图找来了查看图片
点赞 评论 收藏
分享
白火同学:能。我当初应届沟通了1200,收简历50,面试10左右吧,加油投吧
投了多少份简历才上岸
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务