首頁 >後端開發 >Python教學 >Python求兩個數的最大公約數

Python求兩個數的最大公約數

angryTom
angryTom原創
2020-02-07 09:33:2719886瀏覽

Python求兩個數的最大公約數

Python求兩個數的最大公約數

#一、求最大公約數演算法:

1. 整數A對整數B進行取整, 餘數用整數C來表示    舉例: C = A % B

2. 如果C等於0,則C就是整數A和整數B的最大公約數

3. 如果C不等於0, 將B賦值給A, 將C賦值給B ,然後進行1, 2 兩步,直到餘數為0, 則可以得知最大公約數

二、根據演算法,實作Python程式

def fun(num1, num2):  # 定义一个函数, 两个形参
    if num1 < num2:  # 判读两个整数的大小,目的为了将大的数作为除数,小的作为被除数
        num1, num2 = num2, num1  # 如果if条件满足,则进行值的交换

    vari1 = num1 * num2  # 计算出两个整数的乘积,方便后面计算最小公倍数
    vari2 = num1 % num2  # 对2个整数进行取余数

    while vari2 != 0:  # 判断余数是否为0, 如果不为0,则进入循环
        num1 = num2  # 重新进行赋值,进行下次计算
        num2 = vari2
        vari2 = num1 % num2  # 对重新赋值后的两个整数取余数
        
        # 直到 vari2 等于0,得到最到公约数就退出循环

    vari1 /= num2   # 得出最小公倍数
    print("最大公约数为:%d" % num2)    # 输出
    print("最小公倍数为:%d" % vari1)   # 输出


fun(6, 9)

程式輸出結果:

最大公约数为:3
最小公倍数为:18

推薦:Python教學

#

以上是Python求兩個數的最大公約數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn