日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

数据结构与算法—递归算法(从阶乘、斐波那契到汉诺塔的递归图解)

發(fā)布時間:2025/3/20 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数据结构与算法—递归算法(从阶乘、斐波那契到汉诺塔的递归图解) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

目錄

  • 遞歸介紹
  • 遞歸求階乘
  • 遞歸求斐波那契
  • 遞歸解決漢諾塔
  • 總結(jié)

遞歸介紹

遞歸:就是函數(shù)自己調(diào)用自己。 子問題須與原始問題為同樣的事,或者更為簡單;
遞歸通常可以簡單的處理子問題,但是不一定是最好的。

對于遞歸要分清以下概念:

  • 自己調(diào)用自己
  • 遞歸通常不在意具體操作,只關(guān)心初始條件和上下層的變化關(guān)系。
  • 遞歸函數(shù)需要有臨界停止點,即遞歸不能無限制的執(zhí)行下去。通常這個點為必須經(jīng)過的一個數(shù)。
  • 遞歸通常能被其他方案替代(棧、數(shù)組正向求)。

認識遞歸,遞歸函數(shù)通常簡易但是對于初學(xué)者可能很難取理解它。拿一個遞歸函數(shù)來說。

static void digui() {System.out.println("bigsai前");digui();System.out.println("bigsai后"); }

是一個遞歸吧?
不是正常遞歸,沒有結(jié)束條件,自己一致調(diào)用自己死循環(huán)。
那正確的遞歸應(yīng)該這樣

static void digui(int time) {if(time==0) {}//time==0不執(zhí)行else {System.out.println("bigsai前time: "+time);digui(time-1);System.out.println("bigsai后time: "+time); } }

對于這樣一種遞歸,它的執(zhí)行流程大致是這樣的

所以,調(diào)用dugui(5)在控制臺輸出是這樣的

那么,我想你對遞歸函數(shù)執(zhí)行的流程應(yīng)該有所了解了吧。

遞歸求階乘

求 n!=n*(n-1)*-----*1=n!=n*(n-1)!
所以階乘的上下級的關(guān)系很容易找到。我們假設(shè)一個函數(shù)jiecheng(n)為求階乘的函數(shù)。
這個階乘,你可以這樣命名:

int jiecheng(int n) {int va=1;for(int i=n;i>0;i--){va*=i;}return i; }

但是你還可以簡便這樣:

static int jiecheng(int n) {if(n==0)//0的階乘為1{return 1;}else {return n*jiecheng(n-1);//return n*(n-1)*jiecheng(n-2)=-------} }

運行流程為這樣:

遞歸求斐波那契

按照上述思想,我們假設(shè)求斐波那契設(shè)成F(n);
首先,斐波那契的公式為:

  • F[n]=F[n-1]+F[n-2](n>=3,F[1]=1,F[2]=1)
  • 也就是除了n=1和2特殊以外,其他均是可以使用遞推式。

那么遞推實現(xiàn)的代碼為:

static long F(int n) {if(n==1||n==2) {return 1;}else {return F(n-1)+F(n-2);} }

其實它的調(diào)用流程為:

當然,其效率雖然不高,可以打表優(yōu)化,后面可能還會介紹矩陣快速冪優(yōu)化!

遞歸解決漢諾塔

漢諾塔是經(jīng)典遞歸問題:

相傳在古印度圣廟中,有一種被稱為漢諾塔(Hanoi)的游戲。該游戲是在一塊銅板裝置上,有三根桿(編號A、B、C),在A桿自下而上、由大到小按順序放置64個金盤(如下圖)。游戲的目標:把A桿上的金盤全部移到C桿上,并仍保持原有順序疊好。操作規(guī)則:每次只能移動一個盤子,并且在移動過程中三根桿上都始終保持大盤在下,小盤在上,操作過程中盤子可以置于A、B、C任一桿上。

  • 如果A只有一個(A->C)
  • 如果A有兩個(A->B),(A->C),(B->C)
  • 如果A有三個(A->C),(A->B),(C->B),(A->C),(B->A),(B->C),(A->C).
  • 如果更多,那么將會爆炸式增長。
  • 可以發(fā)現(xiàn)每增加一步,其中的步驟會多很多。但是不妨這樣想:

    • 當有1個要從A->C時,且已知移動方式。使用函數(shù)表示move(a->c)。同理其他move操作。
    • -------省略中間若干步驟不看,用遞歸思想看問題

    分析:n個從a—>c和n-1個a—>c有什么聯(lián)系?(hannuo(n)—>hannuo(n-1)有啥關(guān)系)
    假設(shè)有n個盤子

    • hannuo(n-1)之后n-1個盤子從A—>C.
    • 此時剩下底下最大的,只能移動到B,move(A,B)
    • 那么你是否發(fā)現(xiàn)什么眉目了,只需原先的huannuo(n-1)相同操作從C—>B即可完成轉(zhuǎn)移到B;那么我們的之前函數(shù)應(yīng)該寫成hannuo(n-1,A,C)但是又用到B,所以把B傳進來hannuo(n-1,A,B,C)先表示為從n-1個從A(借助B執(zhí)行若干操作)轉(zhuǎn)到C
    • 這一系列操作使得將n個盤子從A—>B但是我們要的是A—>C才是需要的hannuo(n,A,B,C);那么我們只需要更改下hannuo(n-1,----)順序就好啦!

    經(jīng)過上面分析,那么完整的操作為:

    package 遞歸; public class hannuota {static void move(char a,char b){System.out.println("移動最上層的"+ a+ "到"+ b+ "\t");}static void hannuota(int n,char a,char b,char c)//主要分析每一大步對于下一步需要走的。{if(n==1) {move(a,c);}//從a移到celse{hannuota(n-1,a,c,b);//將n-1個從a借助c移到bmove(a,c); //將第n(最后一個)從a移到c。hannuota(n-1,b,a,c);//再將n-1個從b借助a移到c}}public static void main(String[] args){hannuota(5,'a','b','c');} }

    總結(jié)

    其實遞歸在某些場景的效率是很低下的。尤其是斐波那契.從圖你就可以發(fā)現(xiàn)一個簡單的操作有多次重復(fù)。因為它的遞歸調(diào)用倆個自己.那么它的遞歸的膨脹率是指數(shù)級別的,重復(fù)了大量相同計算。當然這種問題也有優(yōu)化方案的:

    • 從前往后打表計算,采用類似動態(tài)規(guī)劃的思想。從前往后考慮。比如斐波那契F[n]=F[n-1]+F[n-2];那么我用數(shù)組儲存。從第三項開始F[3]=F[2]+F[1](均已知),再F[4]=F[3]+F[2]-----這樣,時間復(fù)雜度是O(N),線性的。
    • 當然,對于階乘那種遞歸雖然時間是沒有減少,但是如果需要多次訪問一個階乘,那么可以采用同樣思想(打表)解決問題。

    最后,筆者能力有限,如果有描述不恰當還請指正,感謝前面動態(tài)圖(未找到原作者)和漢諾塔動圖開源作者isea533的開源作品。同時,如果有喜歡學(xué)習(xí)交流的歡迎關(guān)注筆者公眾號:bigsai 回復(fù)bigsai贈送精美資料一份!

    總結(jié)

    以上是生活随笔為你收集整理的数据结构与算法—递归算法(从阶乘、斐波那契到汉诺塔的递归图解)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 日韩在线国产精品 | 欧美大片免费看 | 精品久久一区二区 | 亚洲色偷偷色噜噜狠狠99网 | 男人操女人动态图 | 日韩欧美的一区二区 | av片亚洲 | 亚洲免费观看视频 | 国模大尺度视频 | 国产激情久久久久久熟女老人av | 96久久久 | 最近中文字幕第一页 | 久久久久久久一 | 久久人体视频 | 天天射夜夜 | 操极品少妇 | 日韩欧美成 | 欧美日韩不卡合集视频 | 久久久久久免费观看 | 含羞草一区二区三区 | 免费a级| 中文字幕av影片 | 另类第一页 | 午夜激情视频在线观看 | 国产av天堂无码一区二区三区 | 亚洲精品h| 亚洲中文字幕一区 | 国产成人无码一区二区在线播放 | 久久精品aⅴ无码中文字字幕重口 | 久久久男人天堂 | 成人在线观看网 | 成人播放器 | 国产第3页 | 学生孕妇videosex性欧美 | 日韩激情久久 | 四虎久久久 | 91视频社区| 怡红院av久久久久久久 | 国产98在线| 久操香蕉 | 777奇米四色 | 国产精品乱码一区 | 欧美日韩视频无码一区二区三 | 精品人妻大屁股白浆无码 | 可以在线观看的av网站 | 国产欧美日韩中文字幕 | av观看免费 | 国产人妖一区二区 | 在线播放你懂得 | а√天堂资源官网在线资源 | www色亚洲 | 在线观看色网站 | 男人天堂电影 | 女人扒开屁股让我添 | 99精品一级欧美片免费播放 | 欧美性生活精品 | 影音先锋国产在线 | 操操操操操操操 | 99re8在线精品视频免费播放 | www.欧美一区二区三区 | 91大神在线观看视频 | 青青青草视频在线 | 亚洲免费国产视频 | 日本一区二区视频免费 | 在线免费看污网站 | 国产成人不卡 | 国产三级免费观看 | 深夜视频在线免费 | 91高清在线免费观看 | 婷婷777| 亚洲狠狠婷婷综合久久久久图片 | 无码人妻丰满熟妇区毛片蜜桃精品 | 五月婷网站 | jizz91| 国内精品人妻无码久久久影院蜜桃 | 亚洲网在线观看 | 五个女闺蜜把我玩到尿失禁 | 黄色av网址大全 | 国产免费色视频 | 99国产精品久久久久久久成人热 | 日韩视频区 | 亚洲激情区 | 国产精品一二三四五区 | 亚洲av无码片一区二区三区 | 手机av在线播放 | 神马香蕉久久 | 天堂资源最新在线 | 成人国产a| www.夜夜操.com| 免费一级黄 | 污色视频 | 欧美激情一级精品国产 | 东北女人av | 中国一级免费毛片 | 亚洲成人v | 欧美性xxxxx极品少妇 | 欧美少妇精品 | 青青青草视频在线 | 抽插丰满内射高潮视频 |