国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python二叉樹的定義及常用遍歷算法分析

2020-01-04 16:15:30
字體:
供稿:網(wǎng)友

本文實(shí)例講述了Python二叉樹的定義及常用遍歷算法。分享給大家供大家參考,具體如下:

說起二叉樹的遍歷,大學(xué)里講的是遞歸算法,大多數(shù)人首先想到也是遞歸算法。但作為一個(gè)有理想有追求的程序員。也應(yīng)該學(xué)學(xué)非遞歸算法實(shí)現(xiàn)二叉樹遍歷。二叉樹的非遞歸算法需要用到輔助棧,算法著實(shí)巧妙,令人腦洞大開。

以下直入主題:

定義一顆二叉樹,請(qǐng)看官自行想象其形狀,

class BinNode( ):  def __init__( self, val ):    self.lchild = None    self.rchild = None    self.value = valbinNode1 = BinNode( 1 )binNode2 = BinNode( 2 )binNode3 = BinNode( 3 )binNode4 = BinNode( 4 )binNode5 = BinNode( 5 )binNode6 = BinNode( 6 )binNode1.lchild = binNode2binNode1.rchild = binNode3binNode2.lchild = binNode4binNode2.rchild = binNode5binNode3.lchild = binNode6

先序遍歷:

'''先序遍歷二叉樹'''def bin_tree_pre_order_traverse( root, visit_func ):  s = Stack()  s.push( root )  while not s.is_empty():    node = s.pop()    visit_func( node )    if node.rchild:      s.push( node.rchild )    if node.lchild:      s.push( node.lchild )

中序遍歷:

'''中序遍歷二叉樹'''def bin_tree_in_order_traverse( root, visit_func ):  s = Stack()  node = root  while node or not s.is_empty():    if node:      s.push( node )      node = node.lchild    else:      node = s.pop()      visit_func( node )      node = node.rchild

后序遍歷:

后序遍歷中,要保證左孩子和右孩子都已被訪問才能訪問根結(jié)點(diǎn),并且左孩子需在右孩子前訪問,這就為流程的控制帶來了難題。下面介紹兩種思路。

思路一,雙棧法,這種方式比較容易理解,缺點(diǎn)是需要兩個(gè)棧。

'''后序遍歷二叉樹'''def bin_tree_post_order_traverse( root, visit_func ):  s1 = Stack()  s2 = Stack()  s1.push( root )  while not s1.is_empty():    node = s1.pop()    s2.push( node )    if node.lchild:      s1.push( node.lchild )    if node.rchild:      s1.push( node.rchild )  while not s2.is_empty():    visit_func( s2.pop() )

思路二,要保證根結(jié)點(diǎn)在左孩子和右孩子訪問之后才能訪問,因此對(duì)于任一結(jié)點(diǎn)P,先將其入棧。如果P不存在左孩子和右孩子,則可以直接訪問它;或者P存在左孩子或者右孩子,但是其左孩子和右孩子都已被訪問過了,則同樣可以直接訪問該結(jié)點(diǎn)。若非上述兩種情況,則將P的右孩子和左孩子依次入棧,這樣就保證了每次取棧頂元素的時(shí)候,左孩子在右孩子前面被訪問,左孩子和右孩子都在根結(jié)點(diǎn)前面被訪問。

def bin_tree_post_order_traverse2( root, visit_func ):  curr = root  prev = None  s = Stack()  s.push( curr )  while not s.is_empty():    curr = s.peek()    if ( not curr.lchild and not curr.rchild ) or ( prev and ( prev == curr.lchild or prev == curr.rchild ) ):      visit_func( curr )      s.pop()       prev = curr    else:      if curr.rchild:        s.push( curr.rchild )      if curr.lchild:        s.push( curr.lchild )

層序遍歷:

def bin_tree_level_traverse( root, visit_func ):  queue = Queue()  queue.enqueue( root )  while not queue.is_empty():    node = queue.dequeue().value    visit_func( node )    if node.lchild:      queue.enqueue( node.lchild )    if node.rchild:      queue.enqueue( node.rchild )

 

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到python教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 岐山县| 新平| 武川县| 普兰店市| 马公市| 镇远县| 武乡县| 灵川县| 通州市| 府谷县| 厦门市| 娄底市| 阿拉善右旗| 军事| 罗源县| 尚义县| 临海市| 柳江县| 武陟县| 论坛| 镇远县| 汝南县| 射阳县| 阿克陶县| 名山县| 中西区| 贵定县| 穆棱市| 拜城县| 昌图县| 民权县| 静安区| 绍兴市| 涟源市| 文登市| 嘉善县| 浦县| 双峰县| 双峰县| 双峰县| 名山县|