欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python基于輾轉相除法求解最大公約數(shù)的方法示例

 更新時間:2018年04月04日 10:25:22   作者:grey_csdn  
這篇文章主要介紹了Python基于輾轉相除法求解最大公約數(shù)的方法,結合實例形式分析了Python使用輾轉相除法求解最大公約數(shù)的實現(xiàn)方法與優(yōu)化操作技巧,需要的朋友可以參考下

本文實例講述了Python基于輾轉相除法求解最大公約數(shù)的方法。分享給大家供大家參考,具體如下:

之前總結過一次高德納TAOCP中的最大公約數(shù)求解,其實課后題中的算法修改要求實現(xiàn)的是輾轉相除法求解最大公約數(shù)。

這個題目我最初的理解理解錯了,自然也沒有做出標準答案。現(xiàn)在按照標準答案的解答寫一下相應的代碼實現(xiàn):

# -*- coding:utf-8 -*-
#! python2
def MaxCommDivisor(m,n):
  while m * n != 0:
    m = m % n
    if m == 0:
      return n
    else:
      n = n % m
      if n == 0:
        return m
print(MaxCommDivisor(55,120))

程序的執(zhí)行結果:

交換一下兩個數(shù)字的位置,代碼如下:

# -*- coding:utf-8 -*-
#! python2
def MaxCommDivisor(m,n):
  while m * n != 0:
    m = m % n
    if m == 0:
      return n
    else:
      n = n % m
      if n == 0:
        return m
print(MaxCommDivisor(120,55))

程序的執(zhí)行結果:

題目提示中提到了會降低效率,通過上面的代碼來看,效率的損失應該是在除法以及判斷上。在此,把之前算法的代碼拿過來對比一下:

def CommDevisor(m,n):
  r = m % n
  while r != 0:
    m = n
    n = r
    r = m % n
  return n
print(CommDevisor(120,25))

運行結果:

新算法在循環(huán)中,多了一個除法以及比較操作。其實,比較的效率還是不錯的,但是除法的運算會導致效率的降低。

PS:這里再為大家推薦幾款計算工具供大家進一步參考借鑒:

在線一元函數(shù)(方程)求解計算工具:
http://tools.jb51.net/jisuanqi/equ_jisuanqi

科學計算器在線使用_高級計算器在線計算:
http://tools.jb51.net/jisuanqi/jsqkexue

在線計算器_標準計算器:
http://tools.jb51.net/jisuanqi/jsq

更多關于Python相關內容感興趣的讀者可查看本站專題:《Python數(shù)學運算技巧總結》、《Python數(shù)據(jù)結構與算法教程》、《Python函數(shù)使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總

希望本文所述對大家Python程序設計有所幫助。

相關文章

  • Python基礎之函數(shù)基本用法與進階詳解

    Python基礎之函數(shù)基本用法與進階詳解

    這篇文章主要介紹了Python基礎之函數(shù)基本用法與進階,結合實例形式總結分析了Python函數(shù)的定義、參數(shù)、返回值及遞歸等相關使用技巧與操作注意事項,需要的朋友可以參考下
    2020-01-01
  • python多環(huán)境切換及pyenv使用過程詳解

    python多環(huán)境切換及pyenv使用過程詳解

    這篇文章主要介紹了python多環(huán)境切換及pyenv使用過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-09-09
  • PyTorch: Softmax多分類實戰(zhàn)操作

    PyTorch: Softmax多分類實戰(zhàn)操作

    這篇文章主要介紹了PyTorch: Softmax多分類實戰(zhàn)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • 淺談Keras中shuffle和validation_split的順序

    淺談Keras中shuffle和validation_split的順序

    這篇文章主要介紹了淺談Keras中shuffle和validation_split的順序,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • python Django模板的使用方法

    python Django模板的使用方法

    這篇文章主要為大家介紹了python Django模板的使用方法,代碼很詳細,感興趣的小伙伴們可以參考一下
    2016-01-01
  • numpy之sum()的使用及說明

    numpy之sum()的使用及說明

    這篇文章主要介紹了numpy之sum()的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Python時間的精準正則匹配方法分析

    Python時間的精準正則匹配方法分析

    這篇文章主要介紹了Python時間的精準正則匹配方法,結合實例形式對比分析了Python針對時間格式相關正則匹配技巧,需要的朋友可以參考下
    2017-08-08
  • Python中re模塊常用方法總結分析

    Python中re模塊常用方法總結分析

    這篇文章主要為大家介紹了Python中re模塊常用方法,并對這些常用方法進行總結分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-09-09
  • Python人臉識別之微笑檢測

    Python人臉識別之微笑檢測

    Python可以從圖像或視頻中檢測和識別你的臉,人臉檢測與識別也是計算機視覺領域的研究熱點之一。本文主要為大家介紹通過Python實現(xiàn)人臉識別之微信檢測,需要的同學可以參考一下
    2021-12-12
  • Python數(shù)據(jù)分析numpy文本數(shù)據(jù)讀取索引切片實例詳解

    Python數(shù)據(jù)分析numpy文本數(shù)據(jù)讀取索引切片實例詳解

    這篇文章主要為大家介紹了Python數(shù)據(jù)分析numpy文本數(shù)據(jù)讀取索引切片實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08

最新評論