<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 73,  comments - 55,  trackbacks - 0
    一,兩個數的最大公約數:

    1、歐幾里德算法


    歐幾里德算法又稱輾轉相除法,用于計算兩個整數a,b的最大公約數。其計算原理依賴于下面的定理:

    定理:gcd(a,b) = gcd(b,a mod b)

    證明:a可以表示成a = kb + r,則r = a mod b
    假設d是a,b的一個公約數,則有
    d|a, d|b,而r = a - kb,因此d|r
    因此d是(b,a mod b)的公約數

    假設d 是(b,a mod b)的公約數,則
    d | b , d |r ,但是a = kb +r
    因此d也是(a,b)的公約數

    因此(a,b)和(b,a mod b)的公約數是一樣的,其最大公約數也必然相等,得證

    歐幾里德算法就是根據這個原理來做的,其算法用C++語言描述為:

    void swap(int & a, int & b){
         int c = a;
           a = b;
           b = c;
    }

    int gcd(int a,int b){
         if(0 == a ){
             return b;
         }
         if( 0 == b){
             return a;
         }
         if(a > b){
             swap(a,b);
         }
         int c;
         for(c = a % b ; c > 0 ; c = a % b){
               a = b;
               b = c;
         }
         return b;
    }

    2、Stein算法
    歐幾里德算法是計算兩個數最大公約數的傳統算法,它無論從理論還是從效率上都是很好的。但是有一個致命的缺陷,這個缺陷只有在大素數時才會顯現出來。

    考慮現在的硬件平臺,一般整數最多也就是64位,對于這樣的整數,計算兩個數之間的模是很簡單的。對于字長為32位的平臺,計算兩個不超過32位的整數的 模,只需要一個指令周期,而計算64位以下的整數模,也不過幾個周期而已。但是對于更大的素數,這樣的計算過程就不得不由用戶來設計,為了計算兩個超過 64位的整數的模,用戶也許不得不采用類似于多位數除法手算過程中的試商法,這個過程不但復雜,而且消耗了很多CPU時間。對于現代密碼算法,要求計算 128位以上的素數的情況比比皆是,設計這樣的程序迫切希望能夠拋棄除法和取模。

    Stein算法由J. Stein 1961年提出,這個方法也是計算兩個數的最大公約數。和歐幾里德算法 算法不同的是,Stein算法只有整數的移位和加減法,這對于程序設計者是一個福音。

    為了說明Stein算法的正確性,首先必須注意到以下結論:

    gcd(a,a) = a,也就是一個數和它自身的公約數是其自身
    gcd(ka,kb) = k gcd(a,b),也就是最大公約數運算和倍乘運算可以交換,特殊的,當k=2時,說明兩個偶數的最大公約數必然能被2整除

    C++/java 實現

    // c++/java stein 算法
    int gcd(int a,int b){
         if(a<b){
    //arrange so that a>b
             int temp = a;
               a = b;
               b=temp;
         }
         if(0==b)
    //the base case
            return a;
         if(a%2==0 && b%2 ==0)
    //a and b are even
             return 2*gcd(a/2,b/2);
         if ( a%2 == 0)
    // only a is even
             return gcd(a/2,b);
         if ( b%2==0 )
    // only b is even
             return gcd(a,b/2);
         return gcd((a+b)/2,(a-b)/2);
    // a and b are odd
    }

    二,多個數的最大公約數:(python實現:取出數組a中最小的,從2到最小的循環,找出其中最大的能被數組中所有數整除的那個數,就是最大公約數)
    def gcd(a):
        a.sort()
        min = a[0]
        result = 1
        for i in range(2, min+1):
            flag = True
            for j in a:
                if j % i != 0:
                    flag = False
            if flag == True:
                result = i
        return result
    posted on 2007-12-15 15:40 保爾任 閱讀(4681) 評論(2)  編輯  收藏 所屬分類: Arithmetic & Data Structure

    FeedBack:
    # re: 求兩個數或多個數的最大公約數算法及其實現
    2008-02-16 02:20 | no name
    傳說 歐幾里德算法 一行就可以搞定了
    int gcd(int a,int b){return b==0?a:gcd(b,a%b);}  回復  更多評論
      
    # re: 求兩個數或多個數的最大公約數算法及其實現
    2008-02-16 02:22 | 偶爾郁悶
    對于N個數的話……做N-1次歐幾里德應該會更快些

    你這種做法 如果有100000個數 分別是1000000 或 2000000 那將是很恐怖的事情
      回復  更多評論
      

    <2007年12月>
    2526272829301
    2345678
    9101112131415
    16171819202122
    23242526272829
    303112345

    常用鏈接

    留言簿(4)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 三年片在线观看免费西瓜视频 | 2021久久精品免费观看| 国内精品99亚洲免费高清| 精品特级一级毛片免费观看| 国产精品四虎在线观看免费 | 亚洲成在人天堂一区二区| 国产在线国偷精品免费看| 中文亚洲AV片不卡在线观看| 国产免费黄色无码视频| 亚洲一区二区三区偷拍女厕| 国产精品99精品久久免费| 亚洲成人精品久久| 国产精品永久免费10000| 2020天堂在线亚洲精品专区| 免费黄色一级毛片| 青娱乐在线免费观看视频| 久久亚洲中文字幕精品一区四| 中文字幕视频免费在线观看| 亚洲韩国—中文字幕| 毛片免费全部播放无码| 亚洲最大无码中文字幕| 亚洲成A人片在线观看无码3D| 高清免费久久午夜精品| 午夜亚洲www湿好大| 毛片免费观看网址| 国产成人综合亚洲绿色| 亚洲中文字幕在线第六区| 99热这里有免费国产精品| 亚洲色偷偷综合亚洲AV伊人蜜桃| 四虎影在线永久免费四虎地址8848aa | 美女视频黄a视频全免费网站一区 美女视频黄a视频全免费网站色 | 亚洲熟妇中文字幕五十中出| 欧洲人免费视频网站在线| 亚洲精品无码久久毛片波多野吉衣| 成人无码区免费A片视频WWW| 免费人成视频在线播放| 久久精品亚洲综合一品| 国产精品视频永久免费播放| 国产99视频精品免费视频76| avtt天堂网手机版亚洲| 亚洲国产V高清在线观看|