百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

用Python求最小公倍数的代码汇总及详解

itomcoil 2025-01-06 13:21 19 浏览

#头条创作挑战赛#

最小公倍数之Python代码汇总及详解

1.摘要

在本文中主要进行以下工作,①首先分析了最小公倍数基本概念,其次针对概念设计方法。②方法1:根据最大公约数来求最小公倍数。③方法2:设置循环计算最小公倍数;④进行拓展可以实现多次最小公倍数计算。最后对每种方法都给出了对应的实例演示及效果。

2.步骤

1.首先我们使用方法1,具体思路为:最小公倍数=两数相乘÷两数的最大公约数, 举例子,比如:12和9的最大公因数是3,两数相乘12*9=108/3=36。36就是12和9的最小公倍数呢。 所以,我们首先需要实现求最大公约数,具体代码如下所示。可以先判断输入的a和b的大小,当然也可以不进行判断,无非就是循环中取余的操作会多执行一次。

  # 定义方法求最大公约数 Greatest Common Divisor(GCD)
  def gcd(a, b):
      r = 1 # 余数r
      tmp = 0
      if a < b:
          tmp = a
          a = b
          b = tmp
      while(r != 0):
          r = a % b
          a = b
          b = r
      return a # 此时,a为最后一次相除的除数,即a,b的最大公因数

其中,辗转相除法的算法步骤如下所示。

①第一步,给定两个正整数a,b;

②第二步,计算a除以b所得的余数r ;

③第三步,a=b,b=r ;

④第四步,若r=0,则a,b的最大公约数等于a,否则,返回 第二步。

在计算得到最大公约数后,根据最小公倍数=两数相乘÷两数的最大公约数,计算得到最小公倍数,具体代码如下:

  
  # 定义方法求最小公倍数  Least Common Multiple
  def lcm(a, b):
      init_a, init_b = a, b
      r = 1 # 余数r
      tmp = 0
      while(r != 0):
          r = a % b
          a = b
          b = r
      return init_a * init_b // a # 此时,a为最后一次相除的除数,即a,b的最大公因数

运行结果如下所示。如12和15的最小公倍数为60,13和21的最小公倍数为273。

  In [11]: # 定义方法求最小公倍数  Least Common Multiple
      ...: def lcm(a, b):
      ...:     init_a, init_b = a, b
      ...:     r = 1 # 余数r
      ...:     tmp = 0
      ...:     while(r != 0):
      ...:         r = a % b
      ...:         a = b
      ...:         b = r
      ...:     return init_a * init_b // a # 此时,a为最后一次相除的除数,即a,b的最大公因数
      ...:
  
  In [12]: aa = lcm(12, 15)
  In [13]: aa
  Out[13]: 60
  
  In [14]: lcm(12, 15)
  Out[14]: 60
  
  In [15]: lcm(15, 12)
  Out[15]: 60
  
  In [16]: lcm(5, 2)
  Out[16]: 10
  
  In [17]: lcm(13, 21)
  Out[17]: 273

2.对于方法2,具体思路分析如下所示。

①首先我们要获取到输入的两个数的更大者,并定义为greater;

同时将greater对输入的两个数进行整除,如果同时满足的话,那么就是最小公倍数。

③否则不断对greater加1,直到能够把这两个数整除,也就是找到了最小公倍数。

  
  # 1. 定义计算最小公倍数的方法
  def lcm(a, b): # Least Common Multiple: 最小公倍数
     # 先获取二者之间更大的数
     if a > b:
         greater = a
     else:
         greater = b
     while(True):
         if((greater % a == 0) and (greater % b == 0)):
             lcm = greater
             break
         greater += 1
     return lcm
  # 2. 获取对应输入
  number1 = int(input("请输入数字1: "))
  number2 = int(input("请输入数字2: "))
  result = lcm(number1, number2)
  print( number1,"和", number2,"的最小公倍数为", result)

如下所示,部分运行结果如下所示。

  
  请输入数字1: 12
  请输入数字2: 15
  12 和 15 的最小公倍数为 60
  
  请输入数字1: 13
  请输入数字2: 21
  13 和 21 的最小公倍数为 273
  

3.再定义了一个简单的求最小公倍数的函数之后,我们在此基础进行拓展,可以让用户求任意一个数的最小公倍数直到停止输入为止。

  
  # 定义方法求最小公倍数  Least Common Multiple
  def lcm(a, b):
      init_a, init_b = a, b
      r = 1 # 余数r
      while(r != 0):
          r = a % b
          a = b
          b = r
      return init_a * init_b // a # 此时,a为最后一次相除的除数,即a,b的最大公因数
  while True:
      choice = int(input("是否继续计算(输入0结束): "))
      if choice == 0:
          break
      else:
          number1 = int(input("请输入数字1: "))
          number2 = int(input("请输入数字2: "))
          result = lcm(number1, number2)
          print( number1,"和", number2,"的最小公倍数为", result)

部分运行结果如下所示。

  
  是否继续计算(输入0结束): 1
  请输入数字1: 12
  请输入数字2: 15
  12 和 15 的最小公倍数为 60
  
  是否继续计算(输入0结束): 1
  请输入数字1: 15
  请输入数字2: 12
  15 和 12 的最小公倍数为 60
  
  是否继续计算(输入0结束): 1
  请输入数字1: 13
  请输入数字2: 21
  13 和 21 的最小公倍数为 273
  是否继续计算(输入0结束):0

相关推荐

selenium(WEB自动化工具)

定义解释Selenium是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。支持的浏览器包括IE(7,8,9,10,11),MozillaF...

开发利器丨如何使用ELK设计微服务中的日志收集方案?

【摘要】微服务各个组件的相关实践会涉及到工具,本文将会介绍微服务日常开发的一些利器,这些工具帮助我们构建更加健壮的微服务系统,并帮助排查解决微服务系统中的问题与性能瓶颈等。我们将重点介绍微服务架构中...

高并发系统设计:应对每秒数万QPS的架构策略

当面试官问及"如何应对每秒几万QPS(QueriesPerSecond)"时,大概率是想知道你对高并发系统设计的理解有多少。本文将深入探讨从基础设施到应用层面的解决方案。01、理解...

2025 年每个 JavaScript 开发者都应该了解的功能

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发。1.Iteratorhelpers开发者...

JavaScript Array 对象

Array对象Array对象用于在变量中存储多个值:varcars=["Saab","Volvo","BMW"];第一个数组元素的索引值为0,第二个索引值为1,以此类推。更多有...

Gemini 2.5编程全球霸榜,谷歌重回AI王座,神秘模型曝光,奥特曼迎战

刚刚,Gemini2.5Pro编程登顶,6美元性价比碾压Claude3.7Sonnet。不仅如此,谷歌还暗藏着更强的编程模型Dragontail,这次是要彻底翻盘了。谷歌,彻底打了一场漂亮的翻...

动力节点最新JavaScript教程(高级篇),深入学习JavaScript

JavaScript是一种运行在浏览器中的解释型编程语言,它的解释器被称为JavaScript引擎,是浏览器的一部分,JavaScript广泛用于浏览器客户端编程,通常JavaScript脚本是通过嵌...

一文看懂Kiro,其 Spec工作流秒杀Cursor,可移植至Claude Code

当Cursor的“即兴编程”开始拖累项目质量,AWS新晋IDEKiro以Spec工作流打出“先规范后编码”的系统工程思维:需求-设计-任务三件套一次生成,文档与代码同步落地,复杂项目不...

「晚安·好梦」努力只能及格,拼命才能优秀

欢迎光临,浏览之前点击上面的音乐放松一下心情吧!喜欢的话给小编一个关注呀!Effortscanonlypass,anddesperatelycanbeexcellent.努力只能及格...

JavaScript 中 some 与 every 方法的区别是什么?

大家好,很高兴又见面了,我是姜茶的编程笔记,我们一起学习前端相关领域技术,共同进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力在JavaScript中,Array.protot...

10个高效的Python爬虫框架,你用过几个?

小型爬虫需求,requests库+bs4库就能解决;大型爬虫数据,尤其涉及异步抓取、内容管理及后续扩展等功能时,就需要用到爬虫框架了。下面介绍了10个爬虫框架,大家可以学习使用!1.Scrapysc...

12个高效的Python爬虫框架,你用过几个?

实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...

pip3 install pyspider报错问题解决

运行如下命令报错:>>>pip3installpyspider观察上面的报错问题,需要安装pycurl。是到这个网址:http://www.lfd.uci.edu/~gohlke...

PySpider框架的使用

PysiderPysider是一个国人用Python编写的、带有强大的WebUI的网络爬虫系统,它支持多种数据库、任务监控、项目管理、结果查看、URL去重等强大的功能。安装pip3inst...

「机器学习」神经网络的激活函数、并通过python实现激活函数

神经网络的激活函数、并通过python实现whatis激活函数感知机的网络结构如下:左图中,偏置b没有被画出来,如果要表示出b,可以像右图那样做。用数学式来表示感知机:上面这个数学式子可以被改写:...