bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

python3怎么實現二叉樹的遍歷與遞歸算法-創新互聯

這篇文章主要介紹python3怎么實現二叉樹的遍歷與遞歸算法,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

目前創新互聯已為上千的企業提供了網站建設、域名、網頁空間、網站托管運營、企業網站設計、太湖網站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協力一起成長,共同發展。python是什么意思

Python是一種跨平臺的、具有解釋性、編譯性、互動性和面向對象的腳本語言,其最初的設計是用于編寫自動化腳本,隨著版本的不斷更新和新功能的添加,常用于用于開發獨立的項目和大型項目。

1、二叉樹的三種遍歷方式

二叉樹有三種遍歷方式:先序遍歷,中序遍歷,后續遍歷 即:先中后指的是訪問根節點的順序 eg:先序 根左右 中序 左根右 后序 左右根

遍歷總體思路:將樹分成最小的子樹,然后按照順序輸出

python3怎么實現二叉樹的遍歷與遞歸算法

1.1 先序遍歷

    a 先訪問根節點

    b 訪問左節點

    c 訪問右節點

    a(b ( d ( h ) )( e ( i ) ))( c ( f )( g )) -- abdheicfg

1.2 中序遍歷

    a 先訪問左節點

    b 訪問根節點

    c 訪問右節點

    ( ( ( h ) d ) b ( ( i ) e ) ) a ( ( f ) c ( g ) ) -- hdbieafcg

1.3后序遍歷

    a 先訪問左節點

    b 訪問右節點

    c 訪問根節點

    ((hd)(ie)b)(fgc)a -- hdiebfgca

2、python3實現樹結構

#實現樹結構的類,樹的節點有三個私有屬性 左指針 右指針 自身的值
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__':
  #實例化根節點
  root_node = Node('a')
  # root_node.set_data('a')
  #實例化左子節點
  left_node = Node('b')
  #實例化右子節點
  right_node = Node('c')
  
  #給根節點的左指針賦值,使其指向左子節點
  root_node.set_left(left_node)
  #給根節點的右指針賦值,使其指向右子節點
  root_node.set_right(right_node)

  print(root_node.get_data(),root_node.get_left().get_data(),root_node.get_right().get_data())

3、實現樹的遞歸遍歷(前 中 后 層次遍歷)

下例是樹的遍歷算法,其中對樹的類進行了優化,

#實現樹結構的類,樹的節點有三個私有屬性 左指針 右指針 自己的值
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、遞歸算法

python3怎么實現二叉樹的遍歷與遞歸算法

python3怎么實現二叉樹的遍歷與遞歸算法

上面兩張圖片是從知乎貼過來的;圖1中返回后會直接返回到上一級的返回,這種想法是不全面的,較合理的返回應該是如圖2 在子函數返回時應返回到調用子函數的節點,這樣在執行完剩余代碼再返回到上一級

如果是按照圖1返回的話二叉樹的遍歷就不能按照上例來實現。

以上是“python3怎么實現二叉樹的遍歷與遞歸算法”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯行業資訊頻道!

分享文章:python3怎么實現二叉樹的遍歷與遞歸算法-創新互聯
轉載來源:http://vcdvsql.cn/article42/cscdhc.html

成都網站建設公司_創新互聯,為您提供微信小程序Google網站維護網站設計域名注冊移動網站建設

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

外貿網站建設