C++ 輾轉相除法 - 求最大公約數

輾轉相除法, 又名歐幾里德算法(Euclidean algorithm)乃求兩個正整數最大公因子的算法。它是已知最古老的算法, 其可追溯至公元前300年前。

來自 百度百科 的介紹,下面就不多廢話了

上代碼:

int BigestFactor(int m,int n)
{
    int r=m;
    while(r!=0)
    {
            r=m%n;
            m=n;
            n=r;         
    }
    return m;
}

代碼思路詳見這張流程圖:


輾轉相除法流程圖

所以來編個程序吧~
分數約分程序:

#include <iostream>

using namespace std;

int BigestFactor(int ,int);

int main()
{
    int m,n=0;   
    cin>>m>>n;
    int bf = BigestFactor(m,n);
    cout<<bf<<endl;
    cout<<m*1.0/bf<<endl<<n*1.0/bf<<endl;
    cin.get();
    cin.get();
    return 0;
}

int BigestFactor(int m,int n)
{
    int r=m;
    while(r!=0)
    {
            r=m%n;
            m=n;
            n=r;         
    }
    return m;
}

不解釋了,自己領悟

最后再紀念一下在公元前300年前發明輾轉相除法的歐幾里得

歐幾里得
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 最大公約數(GCD, Greatest Common Divisor,為簡便下文都使用GCD表示最大公約數):指某...
    JxYoung閱讀 15,208評論 8 16
  • 漫畫算法:輾轉相除法是什么鬼? - 文章 - 伯樂在線 大四畢業前夕,計算機學院的小灰又一次頂著炎炎烈日, 去某I...
    viva158閱讀 1,209評論 0 0
  • 輾轉相除法, 又名歐幾里德算法(Euclidean algorithm)乃求兩個正整數之最大公約數的算法。 算法描...
    環球探測閱讀 533評論 0 0
  • 內疚,是一種比悲傷、憤怒、痛苦等人類其他一切情感更讓人不安、備受煎熬和折磨的情感。內疚,往往是私密的、獨自忍受的、...
    黃博Yolanda閱讀 1,403評論 0 1
  • 上一章 小雯大名葉雯,軍訓時被小木勾搭上,然后就一路走過直到現在,兩人都是安靜而隨和的性子,所以爭執基本是不存在的...
    Yi_氤閱讀 325評論 0 0