python3實(shí)現(xiàn)二叉樹(shù)的遍歷與遞歸算法解析(小結(jié))
1、二叉樹(shù)的三種遍歷方式
二叉樹(shù)有三種遍歷方式:先序遍歷,中序遍歷,后續(xù)遍歷 即:先中后指的是訪問(wèn)根節(jié)點(diǎn)的順序 eg:先序 根左右 中序 左根右 后序 左右根
遍歷總體思路:將樹(shù)分成最小的子樹(shù),然后按照順序輸出
1.1 先序遍歷
a 先訪問(wèn)根節(jié)點(diǎn)
b 訪問(wèn)左節(jié)點(diǎn)
c 訪問(wèn)右節(jié)點(diǎn)
a(b ( d ( h ) )( e ( i ) ))( c ( f )( g )) -- abdheicfg
1.2 中序遍歷
a 先訪問(wèn)左節(jié)點(diǎn)
b 訪問(wèn)根節(jié)點(diǎn)
c 訪問(wèn)右節(jié)點(diǎn)
( ( ( h ) d ) b ( ( i ) e ) ) a ( ( f ) c ( g ) ) -- hdbieafcg
1.3后序遍歷
a 先訪問(wèn)左節(jié)點(diǎn)
b 訪問(wèn)右節(jié)點(diǎn)
c 訪問(wèn)根節(jié)點(diǎn)
((hd)(ie)b)(fgc)a -- hdiebfgca
2、python3實(shí)現(xiàn)樹(shù)結(jié)構(gòu)
#實(shí)現(xiàn)樹(shù)結(jié)構(gòu)的類(lèi),樹(shù)的節(jié)點(diǎn)有三個(gè)私有屬性 左指針 右指針 自身的值 class Node(): def __init__(self,data=None): self._data = data self._left = None self._right = None def set_data(self,data): self._data = data def get_data(self): return self._data def set_left(self,node): self._left = node def get_left(self): return self._left def set_right(self,node): self._right = node def get_right(self): return self._right if __name__ == '__main__': #實(shí)例化根節(jié)點(diǎn) root_node = Node('a') # root_node.set_data('a') #實(shí)例化左子節(jié)點(diǎn) left_node = Node('b') #實(shí)例化右子節(jié)點(diǎn) right_node = Node('c') #給根節(jié)點(diǎn)的左指針賦值,使其指向左子節(jié)點(diǎn) root_node.set_left(left_node) #給根節(jié)點(diǎn)的右指針賦值,使其指向右子節(jié)點(diǎn) root_node.set_right(right_node) print(root_node.get_data(),root_node.get_left().get_data(),root_node.get_right().get_data())
3、實(shí)現(xiàn)樹(shù)的遞歸遍歷(前 中 后 層次遍歷)
下例是樹(shù)的遍歷算法,其中對(duì)樹(shù)的類(lèi)進(jìn)行了優(yōu)化,
#實(shí)現(xiàn)樹(shù)結(jié)構(gòu)的類(lèi),樹(shù)的節(jié)點(diǎn)有三個(gè)私有屬性 左指針 右指針 自己的值 class Node(): def __init__(self,data =None,left=None,right = None): self._data = data self._left = left self._right = right #先序遍歷 遍歷過(guò)程 根左右 def pro_order(tree): if tree == None: return False print(tree._data) pro_order(tree._left) pro_order(tree._right) #后序遍歷 def pos_order(tree): if tree == None: return False # print(tree.get_data()) pos_order(tree._left) pos_order(tree._right) print(tree._data) #中序遍歷 def mid_order(tree): if tree == None: return False # print(tree.get_data()) mid_order(tree._left) print(tree._data) mid_order(tree._right) #層次遍歷 def row_order(tree): # print(tree._data) queue = [] queue.append(tree) while True: if queue==[]: break print(queue[0]._data) first_tree = queue[0] if first_tree._left != None: queue.append(first_tree._left) if first_tree._right != None: queue.append(first_tree._right) queue.remove(first_tree) if __name__ == '__main__': tree = Node('A',Node('B',Node('D'),Node('E')),Node('C',Node('F'),Node('G'))) pro_order(tree) mid_order(tree) pos_order(tree)
4、遞歸算法
上面兩張圖片是從知乎貼過(guò)來(lái)的;圖1中返回后會(huì)直接返回到上一級(jí)的返回,這種想法是不全面的,較合理的返回應(yīng)該是如圖2 在子函數(shù)返回時(shí)應(yīng)返回到調(diào)用子函數(shù)的節(jié)點(diǎn),這樣在執(zhí)行完剩余代碼再返回到上一級(jí)
如果是按照?qǐng)D1返回的話(huà)二叉樹(shù)的遍歷就不能按照上例來(lái)實(shí)現(xiàn)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
wxPython中l(wèi)istbox用法實(shí)例詳解
這篇文章主要介紹了wxPython中l(wèi)istbox用法,以實(shí)例形式較為詳細(xì)的分析了Python使用wxPython中l(wèi)istbox的相關(guān)技巧,需要的朋友可以參考下2015-06-06python Django框架實(shí)現(xiàn)web端分頁(yè)呈現(xiàn)數(shù)據(jù)
這篇文章主要介紹了python Django框架實(shí)現(xiàn)web端分頁(yè)呈現(xiàn)數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10python進(jìn)階教程之文本文件的讀取和寫(xiě)入
這篇文章主要介紹了python進(jìn)階教程之文本文件的讀取和寫(xiě)入,本文講解的是最基本的文件讀取和寫(xiě)入功能,需要的朋友可以參考下2014-08-08Python 中導(dǎo)入csv數(shù)據(jù)的三種方法
這篇文章主要介紹了Python 中導(dǎo)入csv數(shù)據(jù)的三種方法,內(nèi)容比較簡(jiǎn)單,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-11-11使用OpenCV實(shí)現(xiàn)迷宮解密的全過(guò)程
同學(xué)發(fā)了我張迷宮圖片,讓我走迷宮來(lái)緩解暴躁,于是乎就碼了一個(gè)程序出來(lái),下面這篇文章主要給大家介紹了關(guān)于使用OpenCV實(shí)現(xiàn)迷宮解密的相關(guān)資料,需要的朋友可以參考下2022-10-10PyQt5+requests實(shí)現(xiàn)車(chē)票查詢(xún)工具
這篇文章主要為大家詳細(xì)介紹了PyQt5+requests實(shí)現(xiàn)車(chē)票查詢(xún)工具,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01python開(kāi)發(fā)的小球完全彈性碰撞游戲代碼
這篇文章主要介紹了通過(guò)python開(kāi)發(fā)的一個(gè)小球完全彈性碰撞游戲效果,特分享下2013-10-10Python 模擬動(dòng)態(tài)產(chǎn)生字母驗(yàn)證碼圖片功能
這篇文章主要介紹了Python 模擬動(dòng)態(tài)產(chǎn)生字母驗(yàn)證碼圖片,這里給大家介紹了pillow模塊的使用,需要的朋友可以參考下2019-12-12