【题目】
从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。
例如:
给定二叉树: [3,9,20,null,null,15,7],
3
/
9 20
/
15 7
返回其层次遍历结果:
[
[3],
[9,20],
[15,7]
]
提示:
节点总数 <= 1000
【代码】

# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution:
def levelOrder(self, root: TreeNode) -> List[List[int]]:
ans=[]
if not root:
return ans
queue=[root]
while queue:
sz=len(queue)
level=[]
for i in range(sz):
node=queue.pop(0)
level.append(node.val)
if node.left:
queue.append(node.left)
if node.right:
queue.append(node.right)
ans.append(level)
return ans
层次遍历:二叉树按层打印节点值

本文介绍如何使用层次遍历算法解决二叉树问题,以给定的二叉树结构为例,展示如何从根节点开始,逐层打印节点值,每层按照从左到右的顺序。适用于节点总数小于1000的情况。
1176

被折叠的 条评论
为什么被折叠?



