java 求最大公約數

求最大公約數有三種方式

  1. 暴力窮舉法
  2. 輾轉相除法
  3. 更相減損術

暴力窮舉法

暴力窮舉法的思路:從兩個數之間找最小的數,然后用這個數往下減侧蘸,若是兩個數都能夠被整除坑鱼,那個數就是最大公約數

    int maxNumber(int m, int n) {
        int temp = m > n ? n : m;
        for (int i = temp; i > 0; i--) {
            if (m % i == 0 && n % i == 0) {
                return i;
            }
        }
        return 0;
    }

這種算法的效率太慢耳鸯。要是筆試寫這個分分鐘回去等通知樱衷。

輾轉相除法

輾轉相除法有兩種方式,維基百科和百度百科對于輾轉相除法的定義有些出入
百度百科:最大公約數等于a除以b的余數c和b之間的最大公約數店溢。

    int maxNumber(int m, int n) {
        int temp;
        if (n > m) {
            temp = n;
            n = m;
            m = temp;
        }
        if (m % n == 0) {
            return n;
        }
        return maxNumber(n, m % n);
    }

維基百科:最大公約數等于其中較小的數和兩數的差的最大公約數叁熔。

    int maxNumber(int m, int n) {
        int temp;
        if (n > m) {
            temp = n;
            n = m;
            m = temp;
        }
        if (m % n == 0) {
            return n;
        }
        return maxNumber(m - n, n);
    }

更相減損術

更相減損術出自《九章算術》
原文描述:可半者半之,不可半者床牧,副置分母荣回、子之數,以少減多戈咳,更相減損心软,求其等也壕吹。以等數約之。
白話文譯文:如果需要對分數進行約分删铃,那么)可以折半的話耳贬,就折半(也就是用2來約分)。如果不可以折半的話猎唁,那么就比較分母和分子的大小咒劲,用大數減去小數,互相減來減去诫隅,一直到減數與差相等為止腐魂,用這個相等的數字來約分。

  1. 任意給定兩個正整數阎肝;判斷它們是否都是偶數。若是肮街,則用2約簡风题;若不是則執(zhí)行第二步。
  2. 以較大的數減較小的數嫉父,接著把所得的差與較小的數比較沛硅,并以大數減小數。繼續(xù)這個操作绕辖,直到所得的減數和差相等為止摇肌。
  3. 則第一步中約掉的若干個2與第二步中等數的乘積就是所求的最大公約數。
    int maxNumber(int m, int n) {
        if (m == n) {
            return n;
        }
        if (n > m) {
            return maxNumber(n,m);
        }else {
            // 同為偶數
            if((m&1) == 0 && (n&1)==0){
                return maxNumber(m >> 1, n >> 1) << 1;
            }else if((m&1) == 0 && (n&1) !=0){
                return maxNumber(m >>1,n);
            }else if((m&1) != 0 && (n&1) ==0){
                return maxNumber(m,n>>1);
            }else {
                return maxNumber(n,m - n);
            }
        }
    }
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末仪际,一起剝皮案震驚了整個濱河市围小,隨后出現的幾起案子,更是在濱河造成了極大的恐慌树碱,老刑警劉巖肯适,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異成榜,居然都是意外死亡框舔,警方通過查閱死者的電腦和手機,發(fā)現死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進店門赎婚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來刘绣,“玉大人,你說我怎么就攤上這事挣输∥撤铮” “怎么了?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵撩嚼,是天一觀的道長移斩。 經常有香客問我肚医,道長,這世上最難降的妖魔是什么向瓷? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任肠套,我火速辦了婚禮,結果婚禮上猖任,老公的妹妹穿的比我還像新娘你稚。我一直安慰自己,他們只是感情好朱躺,可當我...
    茶點故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布刁赖。 她就那樣靜靜地躺著,像睡著了一般长搀。 火紅的嫁衣襯著肌膚如雪宇弛。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天源请,我揣著相機與錄音枪芒,去河邊找鬼。 笑死谁尸,一個胖子當著我的面吹牛舅踪,可吹牛的內容都是我干的。 我是一名探鬼主播良蛮,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼抽碌,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了决瞳?” 一聲冷哼從身側響起货徙,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎皮胡,沒想到半個月后破婆,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡胸囱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年祷舀,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片烹笔。...
    茶點故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡裳扯,死狀恐怖,靈堂內的尸體忽然破棺而出谤职,到底是詐尸還是另有隱情饰豺,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布允蜈,位于F島的核電站冤吨,受9級特大地震影響蒿柳,放射性物質發(fā)生泄漏。R本人自食惡果不足惜漩蟆,卻給世界環(huán)境...
    茶點故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一垒探、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧怠李,春花似錦圾叼、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至髓介,卻和暖如春惕鼓,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背唐础。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工箱歧, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人彻犁。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓叫胁,卻偏偏與公主長得像凰慈,于是被迫代替她去往敵國和親汞幢。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,779評論 2 354

推薦閱讀更多精彩內容

  • 基本概念 因數 :若A=m×n微谓,則稱m森篷,n是A的因數;A是m豺型,n的倍數 一個數的最大因數和最小倍數都...
    AQ王浩閱讀 2,143評論 0 4
  • 最小公倍數:數論中的一種概念仲智,兩個整數公有的倍數成為他們的公倍數,其中一個最小的公倍數是他們的最小公倍數姻氨,同樣地钓辆,...
    Mr_chong閱讀 1,990評論 0 5
  • 第一章數和數的運算 一概念 (一)整數 1整數的意義 自然數和0都是整數。 2自然數 我們在數物體的時候肴焊,用來表示...
    meychang閱讀 2,603評論 0 5
  • 以前會因為一個人 而戀上一座城 現在更期待去一座陌生的城 從冬天到春天 從陌生到熟悉 經歷風雨前联,刻進心底 這才是屬...
    余楓閱讀 179評論 0 1
  • 背著背包去流浪一直是我的夢想,說走就走娶眷,走到哪里都是我的家似嗤。無奈世界那么大,錢包那么小届宠。雖然走出去的心堅定不移烁落,但...
    向行閱讀 266評論 8 5