python计算两个数的最大公约数和最小公倍数

大家好,本文将围绕python计算两个数的最大公约数和最小公倍数展开说明,python中求两个数的最大公约数和最小公倍数是一个很多人都想弄明白的事情,想搞清楚用python求两个数的最大公约数和最小公倍数需要先了解以下几个事情。

Source code download: 本文相关源码

导读

       最大公因数,也称最大公约数、最大公因子,指两个或多个整数共有约数中最大的一个。a,b的最大公约数记为(a,b),同样的,a,b,c的最大公约数记为(a,b,c),多个整数的最大公约数也有同样的记号PythonTurtle画扇形。求最大公约数有多种方法,常见的有质因数分解法、短除法、辗转相除法、更相减损法。与最大公约数相对应的概念是最小公倍数,a,b的最小公倍数记为[a,b]

欧几里得算法

       欧几里得算法又称辗转相除法,是指用于计算两个非负整数a,b的最大公约数。应用领域有数学和计算机两个方面。计算公式gcd(a,b) = gcd(b,a mod b)。
在这里插入图片描述

递归算法

(英语:recursion algorithm)在计算机科学中是指一种通过重复将问题分解为同类的子问题而解决问题的方法。递归式方法可以被用于解决很多的计算机科学问题,因此它是计算机科学中十分重要的一个概念。绝大多数编程语言支持函数的自调用,在这些语言中函数可以通过调用自身来进行递归。计算理论可以证明递归的作用可以完全取代循环,因此在很多函数编程语言(如Scheme)中习惯用递归来实现循环。
解释摘自百度百科侵权请于联系。

方法一

a = int(input("请输入第一个整数"))  # 1997
b = int(input("请输入第二个整数"))  # 615
y = -1  # 余数 先假设
re = -1  # 除数


def qiou(a, b):
    global y  # 因为是全局变量需要声明
    global re
    while y != 0:  # 当y为0 的时候跳出循环
        y = a % b
        re = b
        qiou(b, y)
qiou(a, b)
print("最大公约数{}".format(re))  # 输出最大公约数.

# 最小公倍数=(a*b)/最大公约数
gbs = (a * b) / re
print("最小公倍数{}".format(gbs))

在这里插入图片描述

方法二

def dd(a, b):
    while (True):
        temp = a % b
        a = b
        b = temp
        if temp == 0:
            break
    print(a)


dd(1997, 615)

在这里插入图片描述

  • 11
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值