Python实现利用最大公约数求三个正整数的最小公倍数示例


Posted in Python onSeptember 30, 2017

本文实例讲述了Python实现利用最大公约数求三个正整数的最小公倍数。分享给大家供大家参考,具体如下:

在求解两个数的小公倍数的方法时,假设两个正整数分别为a、b的最小公倍数为d,最大公约数为c。存在这样的关系d=a*b/c。通过这个关系式,我们可以快速的求出三个正整数的最小公倍数。

def divisor(a,b):
  c = a%b
  while c>0:
    a=b
    b=c
    c=a%b
  return b
x1 = input("input1:")
x2 = input("input2:")
x3 = input("input3:")
x0 = x1*x2/divisor(x1,x2)
x0 = x0*x3/divisor(x0,x3)
print "the least multiple is:%d"%x0

通过函数divisor求解两个数的最大公约数,然后进行两次求解最小公倍数即可知道三个正整数x1、x2、x3的最小公倍数。

其实可以通过divisor1函数求两个数的最小公倍数,再进行嵌套调用实现三个数的最小公倍数。

divisor1函数如下:

def divisor1(a,b):
  a1 = a
  b1 = b
  c = a%b
  while c>0:
    a=b
    b=c
    c=a%b
  return a1*b1/b

嵌套过程如下:

x0 = divisor1(divisor1(x1,x2),x3)

可以求得三个正整数的最小公倍数。

Tip: a-bx=c,可知当一个数为a、b的公约数时,同时也是c的约数。

通过最大公约数即可得到最小公倍数的求解。

def min_multi(a,b):
  return a*b/divisor1(a,b)

求解质数的函数:

def isPrime(n):
  for i in range(2,int(n**0.5)+1):
    if n%i==0:
      return False
  return True

PS:这里再为大家推荐几款计算工具供大家进一步参考借鉴:

在线一元函数(方程)求解计算工具:
http://tools.3water.com/jisuanqi/equ_jisuanqi

科学计算器在线使用_高级计算器在线计算:
http://tools.3water.com/jisuanqi/jsqkexue

在线计算器_标准计算器:
http://tools.3water.com/jisuanqi/jsq

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
零基础写python爬虫之抓取百度贴吧代码分享
Nov 06 Python
Python字符串转换成浮点数函数分享
Jul 24 Python
简单总结Python中序列与字典的相同和不同之处
Jan 19 Python
利用python获取某年中每个月的第一天和最后一天
Dec 15 Python
python+django加载静态网页模板解析
Dec 12 Python
python使用PIL给图片添加文字生成海报示例
Aug 17 Python
opencv3/Python 稠密光流calcOpticalFlowFarneback详解
Dec 11 Python
带你彻底搞懂python操作mysql数据库(cursor游标讲解)
Jan 06 Python
浅谈Python中的异常和JSON读写数据的实现
Feb 27 Python
Django models文件模型变更错误解决
May 11 Python
PyMongo 查询数据的实现
Jun 28 Python
Python几种酷炫的进度条的方式
Apr 11 Python
Python基于pygame模块播放MP3的方法示例
Sep 30 #Python
Python实现自动为照片添加日期并分类的方法
Sep 30 #Python
Python实现获取照片拍摄日期并重命名的方法
Sep 30 #Python
Python3利用SMTP协议发送E-mail电子邮件的方法
Sep 30 #Python
Python字符编码与函数的基本使用方法
Sep 30 #Python
详谈Python高阶函数与函数装饰器(推荐)
Sep 30 #Python
深入浅出学习python装饰器
Sep 29 #Python
You might like
php递归删除目录下的文件但保留的实例分享
2014/05/10 PHP
PHP微信开发之微信消息自动回复下所遇到的坑
2016/05/09 PHP
js常用代码段收集
2011/10/28 Javascript
JS模块与命名空间的介绍
2013/03/22 Javascript
利用js(jquery)操作Cookie的方法说明
2013/12/19 Javascript
javascript 中that的含义示例介绍
2014/05/14 Javascript
详解JavaScript中的事件流和事件处理程序
2016/05/20 Javascript
bootstrap datepicker 与bootstrapValidator同时使用时选择日期后无法正常触发校验的解决思路
2016/09/28 Javascript
Bootstrap3 Grid system原理及应用详解
2016/09/30 Javascript
jQuery实现的购物车物品数量加减功能代码
2016/11/16 Javascript
easyui关于validatebox实现多重规则验证的方法(必看)
2017/04/12 Javascript
详解vee-validate的使用个人小结
2017/06/07 Javascript
VUE 实现滚动监听 导航栏置顶的方法
2018/09/11 Javascript
详解vue的双向绑定原理及实现
2019/05/05 Javascript
vant实现购物车功能
2020/06/29 Javascript
js实现金山打字通小游戏
2020/07/24 Javascript
Vue执行方法,方法获取data值,设置data值,方法传值操作
2020/08/05 Javascript
详解微信小程序(Taro)手动埋点和自动埋点的实现
2021/03/02 Javascript
[54:53]2014 DOTA2国际邀请赛中国区预选赛 LGD-GAMING VS CIS 第二场
2014/05/23 DOTA
python操作xml文件详细介绍
2014/06/09 Python
小白如何入门Python? 制作一个网站为例
2018/03/06 Python
python多线程使用方法实例详解
2019/12/30 Python
python利用后缀表达式实现计算器功能
2021/02/22 Python
canvas实现滑动验证的实现示例
2020/08/11 HTML / CSS
家用个人磨皮机:Trophy Skin
2017/03/30 全球购物
JSF的标签库有哪些
2012/04/27 面试题
部队万能检讨书
2014/02/20 职场文书
《雷雨》教学反思
2014/02/20 职场文书
委托书范文
2014/04/02 职场文书
优秀团员事迹材料2000字
2014/08/20 职场文书
前台文员岗位职责
2015/02/04 职场文书
信息技术国培研修日志
2015/11/13 职场文书
企业管理制度设计时要注意的几种“常见病”!
2019/04/19 职场文书
导游词之河北野三坡
2019/12/11 职场文书
浅谈mysql返回Boolean类型的几种情况
2021/06/04 MySQL
html中两种获取标签内的值的方法
2022/06/16 jQuery