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