揽星星入眠. 2023-04-06 23:36 采纳率: 62.5%
浏览 68
已结题

求两个数的最大公约数和最小公倍数

img


求两个数的最大公约数和最小公倍数,想知道这个程序的问题,报错的解决措施,以及有什么需要改进的,希望能得到各位的解

  • 写回答

2条回答 默认 最新

  • Dummer25 2023-04-06 23:43
    关注

    1.语法错误:
    在第 2 行和第 3 行中,a 和 b 的赋值语句应该分别写成 temp = a % b 和 a = b。此外,在第 4 行遗漏了冒号,需要加上。

    2.逻辑错误:
    该函数的实现逻辑有误,不能正确地计算最大公约数。例如,当输入的两个数为 10 和 25 时,函数会进入死循环,并抛出 RecursionError 异常。

    下面是修改后的代码:

    def fun(a, b):
        while b:
            a, b = b, a % b
        return a
    
    a, b = eval(input("请输入两个正整数:"))
    x = a * b / fun(a, b)
    
    print(f'{a}{b}的最大公约数是{fun(a, b)}')
    print(f'{a}{b}的最小公倍数是{x}')
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月23日
  • 已采纳回答 4月15日
  • 创建了问题 4月6日