python实现二叉树和它的七种遍历
介紹:
樹是數(shù)據(jù)結(jié)構(gòu)中非常重要的一種,主要的用途是用來提高查找效率,對(duì)于要重復(fù)查找的情況效果更佳,如二叉排序樹、FP-樹。另外可以用來提高編碼效率,如哈弗曼樹。?
?
?
?
代碼:
用python實(shí)現(xiàn)樹的構(gòu)造和幾種遍歷算法,雖然不難,不過還是把代碼作了一下整理總結(jié)。實(shí)現(xiàn)功能:
- 樹的構(gòu)造
- 遞歸實(shí)現(xiàn)先序遍歷、中序遍歷、后序遍歷
- 堆棧實(shí)現(xiàn)先序遍歷、中序遍歷、后序遍歷
- 隊(duì)列實(shí)現(xiàn)層次遍歷
?
?
總結(jié):
樹的遍歷主要有兩種,一種是深度優(yōu)先遍歷,像前序、中序、后序;另一種是廣度優(yōu)先遍歷,像層次遍歷。在樹結(jié)構(gòu)中兩者的區(qū)別還不是非常明顯,但從樹擴(kuò)展到有向圖,到無向圖的時(shí)候,深度優(yōu)先搜索和廣度優(yōu)先搜索的效率和作用還是有很大不同的。?
深度優(yōu)先一般用遞歸,廣度優(yōu)先一般用隊(duì)列。一般情況下能用遞歸實(shí)現(xiàn)的算法大部分也能用堆棧來實(shí)現(xiàn)。
我印象中是有遞歸構(gòu)造樹的方法,卻一直想不出該怎么構(gòu)造。后來仔細(xì)想了一下,遞歸思想有點(diǎn)類似深度優(yōu)先算法,而樹的構(gòu)造應(yīng)該是廣度優(yōu)先的。如果用遞歸的話一定要有個(gè)終止條件,例如規(guī)定樹深等。不然構(gòu)造出來的樹會(huì)偏向左單子樹或者右單子樹。所以一般樹的構(gòu)造還是應(yīng)該用隊(duì)列比較好。
以上說的不夠嚴(yán)謹(jǐn),有錯(cuò)誤之處,歡迎指正!
?
轉(zhuǎn)載于:https://www.cnblogs.com/shiguangrenran/p/8143694.html
總結(jié)
以上是生活随笔為你收集整理的python实现二叉树和它的七种遍历的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: jsp servlet中的过滤器Filt
- 下一篇: 【Python】HackBack(获取暴