当前位置:   article > 正文

最小公倍数Python——三种方法

最小公倍数python

最小公倍数 = 两数的乘积 / 最大公约数

辗转相除法(欧几里德法)

这种方法的实现原理是求两个正整数的余数 r,再用两个正整数中的较小数与其再求余直到余数为 0 时,此时的较小数就是最大公约数。最后利用公式计算得到这两个数的最小公倍数。

代码示例:

  1. print("请输入两个正整数:")
  2. m = int(input())
  3. n = int(input())
  4. x = m * n # x用于存放m与n的乘积
  5. print(f"{m}{n}的最小公倍数是:", end='') # 此时输出m和n的值还没改变
  6. r = m % n
  7. while r != 0: # 不用比较大小,若m小于n,则会在第一遍循环交换位置
  8. m = n
  9. n = r
  10. r = m % n
  11. print(x // n)
 

相减法(更相减损法)

这种方法比较易于理解,原理是先判断两个正整数大小,并将较大数与较小数的差值赋给较大数,循环此步骤直到两数相等,此时得出最大公约数。最后利用公式计算得到这两个数的最小公倍数。

代码示例:

  1. print("请输入两个正整数:")
  2. m = int(input())
  3. n = int(input())
  4. x = m * n # x用于存放m与n的乘积
  5. print(f"{m}{n}的最小公倍数是:", end='') # 此时输出m和n的值还没改变
  6. while m != n:
  7. if m > n:
  8. m = m - n
  9. else:
  10. n = n - m
  11. print(x // m)

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/726889
推荐阅读
相关标签
  

闽ICP备14008679号