我试图解决二叉树级别顺序遍历问题 - LeetCode
给定一棵二叉树,返回其节点值的层序遍历。(即从左到右,一层一层)。
例如:给定二叉树[3,9,20,null,null,15,7],
3
/ \
9 20
/ \
15 7
返回其层序遍历为:
[
[3],
[9,20],
[15,7]
]
我的方案很直观,BFS遍历收集每一层的值
from collections import deque
class Solution:
def levelOrder(self, root):
if not root: return [] #base case
res = []
#queue to colloct all the nodes
queue = deque([root])
while queue:
level_vals = [] #hold the values at the current level.
for _ in range(len(queue)): #evalute once before execution enter the loop
cur = queue.popleft()
if node.left:
queue.append(cur.left)
if node.right:
queue.append(cur.right)
level_vals.append(cur.val)
res.append(level_vals)
return res
我在讨论区阅读了这样的 bfs 和队列解决方案
# BFS + deque
def levelOrder(self, root):
res, queue = [], deque([(root, 0)])
while queue:
cur, level = queue.popleft()
if cur:
if len(res) < level+1:
res.append([])
res[level].append(cur.val)
queue.append((cur.left, level+1))
queue.append((cur.right, level+1))
return res
我对条件检查感到困惑if len(res) < level+1: res.append([]),并认为它可以是 '
if cur:
#if len(res) < level+1:
res.append([])
res[level].append(cur.val)
queue.append((cur.left, level+1))
queue.append((cur.right, level+1))
return res
为什么需要条件检查?
慕无忌1623718
相关分类