91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python中遍歷樹的方法有哪些

發布時間:2020-08-10 14:15:59 來源:億速云 閱讀:187 作者:小新 欄目:編程語言

這篇文章主要介紹了python中遍歷樹的方法有哪些,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

各種遍歷順序如下圖所示:

python中遍歷樹的方法有哪些

樹的最大深度 

# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
class Solution(object):
    def maxdepth(self, root):
        if root is None:
            return 0
        return max(self.maxdepth(root.left), self.maxdepth(root.right))+1

深度優先

深度優先遍歷有三種方式:前序遍歷、中序遍歷和后序遍歷

所說的前序、中序、后序,是指根節點的先后順序。

前序遍歷:根節點 -> 左子樹 -> 右子樹

# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
class Solution(object):
    def preorder(self, root):
        if root is None:
            return ''
        print root.val
        if root.lef:
            self.preorder(root.left)
        if root.right:
            self.preorder(root.right)

中序遍歷:左子樹 -> 根節點 -> 右子樹

# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
class Solution(object):
    def midorder(self, root):
        if root is None:
            return ''
        if root.lef:
            self.midorder(root.left)
        print root.val
        if root.right:
            self.midorder(root.right)

后序遍歷:左子樹 -> 右子樹 -> 根節點

# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
class Solution(object):
    def endorder(self, root):
        if root is None:
            return ''
        if root.lef:
            self.endorder(root.left)
        if root.right:
            self.endorder(root.right)
        print root.val

廣度優先

廣度優先遍歷,即層次遍歷,優先遍歷兄弟節點

層次遍歷:根節點 -> 左節點 -> 右節點

# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
class Solution(object):
  def graorder(self, root):
    if root is None:
      return ''
    queue = [root]
    while queue:
      res = []
      for item in queue:
        print item.val,
        if item.left:
          res.append(item.left)
        if item.right:
          res.apppend(item.right)
      queue = res

比較兩棵樹是否相同

# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
class Solution(object):
    def issame(self, root1, root2):
        if root1 is None and root2 is None:
            return True
        elif root1 and root2:
            return root1.val==root2.val and issame(root1.left, root2.left) and issame(root1.right, root2.right)
        else:
            return False

感謝你能夠認真閱讀完這篇文章,希望小編分享python中遍歷樹的方法有哪些內容對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

罗田县| 台北市| 万年县| 昌邑市| 喀喇| 社旗县| 绵阳市| 肃南| 喀喇沁旗| 集安市| 宁强县| 兴仁县| 沾化县| 山丹县| 桐城市| 施秉县| 浑源县| 故城县| 上思县| 桑日县| 积石山| 淮滨县| 新丰县| 虞城县| 江北区| 安宁市| 麻城市| 阿拉善盟| 海城市| 五大连池市| 华容县| 肥城市| 锡林浩特市| 汾阳市| 岳普湖县| 南丹县| 苍南县| 石泉县| 柘荣县| 东城区| 莱州市|