您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關如何求出python二叉樹的深度,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
輸入一棵二叉樹的根節點,求該樹的深度。從根節點到葉節點依次經過的節點(含根、葉節點)形成樹的一條路徑,最長路徑的長度為樹的深度。
給定二叉樹 [3,9,20,null,null,15,7],
3
/ \
9 20
/ \
15 7
返回它的最大深度 3 。
class Solution:
def maxDepth(self, root: TreeNode) -> int:
if not root:
# 遞歸出口, 空節點的情況
return 0
# 當前節點深度是左右子樹的最大深度+1
return 1 + max(self.maxDepth(root.left), self.maxDepth(root.right))
# 也可以進一步簡化為只需要一行代碼..
# return 0 if not root else 1 + max(self.maxDepth(root.left), self.maxDepth(root.right))
class Solution:
def maxDepth(self, root: TreeNode) -> int:
if not root:
return 0
q = [root]
res = 0
while q:
# 當前層節點數目
curlen = len(q)
for node in q[:curlen]:
# 只追加非空子節點
if node.left:
q.append(node.left)
if node.right:
q.append(node.right)
# 隊列切片, 開始處理下一層
q = q[curlen:]
# 當前層遍歷完畢, 深度+1
res += 1
return res
看完上述內容,你們對如何求出python二叉樹的深度有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。