已解决
算法题:二叉树的层序遍历
来自网友在路上 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 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!
- 上一篇: Web3公链之Cosmos生态的项目Celestia
- 下一篇: Excel VBA开发基本语句说明