当前位置:首页 > 编程笔记 > 正文
已解决

算法题:二叉树的层序遍历

来自网友在路上 138838提问 提问时间:2023-11-02 10:49:59阅读次数: 38

最佳答案 问答题库388位专家为你答疑解惑

层序遍历,看似简单,实则陷阱很多,怪不得该题目被认定为中等难度题。此处运用了迭代求解法。(完整题目附在了最后)

# Definition for a binary tree node.
class TreeNode:def __init__(self, val=0, left=None, right=None):self.val = valself.left = leftself.right = rightclass Solution:def levelOrder(self, root):  # 层序排列if not root:return []res = []queue = [root]while len(queue) > 0:size = len(queue)temp = []for i in range(size):  # 确保了每层的结点值在同一个数组内# 通过append、pop(0)的方法用数组构造了一个先进先出的列表node = queue.pop(0)  temp.append(node.val)if node.left:queue.append(node.left)if node.right:queue.append(node.right)res.append(temp)return resif __name__ == '__main__':# 创建一个二叉树tree = TreeNode(3)tree.left = TreeNode(9)tree.right = TreeNode(20)tree.right.left = TreeNode(15)tree.right.right = TreeNode(7)# 执行层序遍历sol = Solution()print(sol.levelOrder(tree))  # [[3], [9, 20], [15, 7]]

 完整题目:

102. 二叉树的层序遍历

给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。

示例 1:

输入:root = [3,9,20,null,null,15,7]
输出:[[3],[9,20],[15,7]]

示例 2:

输入:root = [1]
输出:[[1]]

示例 3:

输入:root = []
输出:[]

提示:

  • 树中节点数目在范围 [0, 2000] 内
  • -1000 <= Node.val <= 1000
查看全文

99%的人还看了

猜你感兴趣

版权申明

本文"算法题:二叉树的层序遍历":http://eshow365.cn/6-30095-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!