python3實現(xiàn)二叉樹的遍歷與遞歸算法解析(小結(jié))
1、二叉樹的三種遍歷方式
二叉樹有三種遍歷方式:先序遍歷,中序遍歷,后續(xù)遍歷 即:先中后指的是訪問根節(jié)點的順序 eg:先序 根左右 中序 左根右 后序 左右根
遍歷總體思路:將樹分成最小的子樹,然后按照順序輸出

1.1 先序遍歷
a 先訪問根節(jié)點
b 訪問左節(jié)點
c 訪問右節(jié)點
a(b ( d ( h ) )( e ( i ) ))( c ( f )( g )) -- abdheicfg
1.2 中序遍歷
a 先訪問左節(jié)點
b 訪問根節(jié)點
c 訪問右節(jié)點
( ( ( h ) d ) b ( ( i ) e ) ) a ( ( f ) c ( g ) ) -- hdbieafcg
1.3后序遍歷
a 先訪問左節(jié)點
b 訪問右節(jié)點
c 訪問根節(jié)點
((hd)(ie)b)(fgc)a -- hdiebfgca
2、python3實現(xiàn)樹結(jié)構(gòu)
#實現(xiàn)樹結(jié)構(gòu)的類,樹的節(jié)點有三個私有屬性 左指針 右指針 自身的值
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__':
#實例化根節(jié)點
root_node = Node('a')
# root_node.set_data('a')
#實例化左子節(jié)點
left_node = Node('b')
#實例化右子節(jié)點
right_node = Node('c')
#給根節(jié)點的左指針賦值,使其指向左子節(jié)點
root_node.set_left(left_node)
#給根節(jié)點的右指針賦值,使其指向右子節(jié)點
root_node.set_right(right_node)
print(root_node.get_data(),root_node.get_left().get_data(),root_node.get_right().get_data())
3、實現(xiàn)樹的遞歸遍歷(前 中 后 層次遍歷)
下例是樹的遍歷算法,其中對樹的類進行了優(yōu)化,
#實現(xiàn)樹結(jié)構(gòu)的類,樹的節(jié)點有三個私有屬性 左指針 右指針 自己的值
class Node():
def __init__(self,data =None,left=None,right = None):
self._data = data
self._left = left
self._right = right
#先序遍歷 遍歷過程 根左右
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、遞歸算法


上面兩張圖片是從知乎貼過來的;圖1中返回后會直接返回到上一級的返回,這種想法是不全面的,較合理的返回應(yīng)該是如圖2 在子函數(shù)返回時應(yīng)返回到調(diào)用子函數(shù)的節(jié)點,這樣在執(zhí)行完剩余代碼再返回到上一級
如果是按照圖1返回的話二叉樹的遍歷就不能按照上例來實現(xiàn)。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python Django框架實現(xiàn)web端分頁呈現(xiàn)數(shù)據(jù)
這篇文章主要介紹了python Django框架實現(xiàn)web端分頁呈現(xiàn)數(shù)據(jù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-10-10
Python 中導(dǎo)入csv數(shù)據(jù)的三種方法
這篇文章主要介紹了Python 中導(dǎo)入csv數(shù)據(jù)的三種方法,內(nèi)容比較簡單,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-11-11
Python 模擬動態(tài)產(chǎn)生字母驗證碼圖片功能
這篇文章主要介紹了Python 模擬動態(tài)產(chǎn)生字母驗證碼圖片,這里給大家介紹了pillow模塊的使用,需要的朋友可以參考下2019-12-12

