国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C > 正文

基于歐幾里德算法的使用

2020-01-26 16:18:44
字體:
供稿:網(wǎng)友

歐幾里德算法稱為輾轉(zhuǎn)相除法,用來求已知m、n兩個自然數(shù)的公因數(shù)。結(jié)合程序說明一下輾轉(zhuǎn)相除的具體情況。

首先看遞歸實現(xiàn):

復(fù)制代碼 代碼如下:

int getcd(int m,int n)
 {
     if (m < 0 || n <0) {
         return 0;
     }
     if(m < n)
     {
         int t = m;
         m = n;
         n = t;
     }
     if(m % n)
     {
         return getcd(n,(m % n));
     }
     else
     {
         return n;
     }
 }

主要計算過程分為三個步驟:

1、對輸入的兩個自然數(shù)m > n取余數(shù)r,使得0<= r < n

2、如果r為0,n即為所求結(jié)果,直接返回

3、r不為0,則賦值m=n,n=r從步驟1開始重新執(zhí)行

  兩自然數(shù)的公因數(shù)的定義說明了計算結(jié)果產(chǎn)生的條件。如果步驟1中計算出的余數(shù)r = 0,則較小的數(shù)為公因數(shù)。如果r!=0則自然數(shù)m、n的關(guān)系可表示為:m = kn + r(其中k為自然數(shù)),等式可以證明能整除m的任何數(shù)必定能整除n和r;等式進一步可變形為:r = m - kn,說明同時整除m、n的任何數(shù)也必定能整除r。也就是說,能整除m、n的數(shù)的集合與整除n、r的數(shù)的集合相等。所以輾轉(zhuǎn)相除的方法成立。
 

再發(fā)布一個循環(huán)實現(xiàn)歐幾里德算法的版本。

復(fù)制代碼 代碼如下:

int getcd2(int m,int n)
 {
     if (m < 0 || n <0) {
         return 0;
     }
     if(m<n)
     {
         int t=m;
         m=n;
         n=t;
     }
     int cd = 1;
     while(1){
         int r = m % n;
         if(0==r)
         {
             cd = n;
             break;
         }
         else {
             m=n;
             n=r;
         }
     }
     return cd;
 }

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 上栗县| 崇明县| 寻甸| 榆社县| 都匀市| 镇沅| 巴里| 衢州市| 明水县| 马边| 巴东县| 肥东县| 阆中市| 塔城市| 莆田市| 河池市| 青海省| 冀州市| 乌拉特中旗| 黄浦区| 张家港市| 武陟县| 莒南县| 海盐县| 元阳县| 南宁市| 阜新市| 开平市| 卓尼县| 金山区| 乾安县| 普格县| 雅安市| 岐山县| 美姑县| 剑阁县| 松江区| 钦州市| 吴堡县| 长治市| 汝州市|