寫遞歸

總結(jié)的寫遞歸的幾種方法:

  1. 第一種是直接有遞推公式玄帕,那么就直接找停止條件就好了畏纲,但是要注意停止條件的嚴(yán)謹(jǐn)性镜沽。如果條件不嚴(yán)謹(jǐn)可能會出現(xiàn)死循環(huán)的情況茵乱。
    比如 斐波那契數(shù)列:f(n)=f(n-1)+f(n-2)
    最大公約數(shù):f(m, n) = f(n, m\%n)

  2. 如果遞推公式不是很明確可以通過一個范式找到遞歸方法芒篷。首先明確函數(shù)功能是什么搜变,然后去找停止條件,最后利用這個函數(shù)在變化里找重復(fù)针炉,再在重復(fù)里找變化挠他,一般是不斷縮小參數(shù)的范圍。
    注意這個參數(shù)有的時候需要額外傳入:
    反轉(zhuǎn)字符串:

static String f(String myString, int begin) {
    
    if (begin == myString.length()-1) {
        return myString.charAt(begin)+"";
        
    }
    return f(myString, begin+1)+myString.charAt(begin);
}

在這里這個 begin 就是一個遞歸變量篡帕,如果不使用這個參數(shù)的話殖侵,還有一個辦法就是在遞歸過程中創(chuàng)建一個新的字符串(比原字符串少一個char),直接遞歸字符串镰烧,但是這樣的話就要創(chuàng)建很多額外的字符串拢军,占用大量的內(nèi)存。

另外需要注意遞歸問題的幾種形式怔鳖,第一種就是向上面例子一樣的單路徑的遞歸茉唉,或者是像漢諾塔或者斐波那契數(shù)列這種的雙分支遞歸,還有可能是類似于雙分支遞歸结执,但是會有判斷舍棄掉一半度陆,比如二分查找的遞歸寫法。

static void hano(int k, String from, String to, String help) {
    if (k == 1) {
        System.out.println("move "+k+" from "+from+" to "+to );
        return;
    }

    hano(k-1, from, help, to);
    System.out.println("move "+k+" from "+from+" to "+to );
    hano(k-1, help, to, from);

}
private static int binerySearch(int[] arr, int low_index, int hight_index, int key){
    if (low_index>hight_index) {
        return -1;
    }
    int mind_index = (low_index+hight_index)>>>1;
    int midVal = arr[mind_index];
    if (midVal<key) {
        return binerySearch(arr, mind_index+1, hight_index, key);
    }
    else if (midVal > key) {
        return binerySearch(arr, low_index, mind_index-1, key);
    }
    else {
        return mind_index;
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末献幔,一起剝皮案震驚了整個濱河市懂傀,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蜡感,老刑警劉巖蹬蚁,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件恃泪,死亡現(xiàn)場離奇詭異,居然都是意外死亡缚忧,警方通過查閱死者的電腦和手機(jī)悟泵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進(jìn)店門杈笔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來闪水,“玉大人,你說我怎么就攤上這事蒙具∏蛴埽” “怎么了?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵禁筏,是天一觀的道長持钉。 經(jīng)常有香客問我,道長篱昔,這世上最難降的妖魔是什么每强? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮州刽,結(jié)果婚禮上空执,老公的妹妹穿的比我還像新娘。我一直安慰自己穗椅,他們只是感情好辨绊,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著匹表,像睡著了一般门坷。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上袍镀,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天默蚌,我揣著相機(jī)與錄音,去河邊找鬼苇羡。 笑死绸吸,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的宣虾。 我是一名探鬼主播惯裕,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼绣硝!你這毒婦竟也來了蜻势?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤鹉胖,失蹤者是張志新(化名)和其女友劉穎握玛,沒想到半個月后够傍,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡挠铲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年冕屯,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拂苹。...
    茶點(diǎn)故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡安聘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出瓢棒,到底是詐尸還是另有隱情浴韭,我是刑警寧澤,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布脯宿,位于F島的核電站念颈,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏连霉。R本人自食惡果不足惜榴芳,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望跺撼。 院中可真熱鬧窟感,春花似錦、人聲如沸财边。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽酣难。三九已至谍夭,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間憨募,已是汗流浹背紧索。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留菜谣,地道東北人珠漂。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像尾膊,于是被迫代替她去往敵國和親媳危。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評論 2 345

推薦閱讀更多精彩內(nèi)容

  • ??腦抽的我上個文章爛尾冈敛,又開新坑待笑,,抓谴,暮蹂,我只能對自己前面開的爛坑說一句:青山不改寞缝,綠水長流,我們有緣再見仰泻!??這...
    大王叫我來巡老和山閱讀 1,329評論 0 6
  • 1,javascript 基礎(chǔ)知識 Array對象 Array對象屬性 Arrray對象方法 Date對象 Dat...
    Yuann閱讀 891評論 0 1
  • 繼承 一荆陆、混入式繼承 二、原型繼承 利用原型中的成員可以被和其相關(guān)的對象共享這一特性集侯,可以實(shí)現(xiàn)繼承被啼,這種實(shí)現(xiàn)繼承的...
    magic_pill閱讀 1,050評論 0 3
  • 今天青石的票圈出鏡率最高的粘衬,莫過于張藝謀的新片終于定檔了荞估。 一張滿溢著水墨風(fēng)的海報一次次的出現(xiàn)在票圈里,也就是老謀...
    青石電影閱讀 10,309評論 1 2
  • 今天主要學(xué)習(xí)了flex布局稚新,學(xué)習(xí)筆記如下: 1.指定flex布局: display:flex(任意容器)...
    riku_lu閱讀 3,133評論 2 3