您当前的位置: 首页 >  Python

Better Bench

暂无认证

  • 0浏览

    0关注

    695博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

【Leetcode刷题Python】剑指 Offer 32 - II. 从上到下打印二叉树 II

Better Bench 发布时间:2022-10-03 21:08:07 ,浏览量:0

1 题目

从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。

例如: 给定二叉树: [3,9,20,null,null,15,7],

    3
   / \
  9  20
    /  \
   15   7

返回其层次遍历结果:

[[3], [9,20], [15,7]]

来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/cong-shang-dao-xia-da-yin-er-cha-shu-ii-lcof 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2 解析

层次遍历,使用队列,在【剑指 Offer 32 - I. 从上到下打印二叉树】上改进即可。即依次遍历队列,将队列中元素加入到列表中,再去加入子节点。

3 python实现
class Solution:
    def levelOrder(self, root: TreeNode) -> List[List[int]]:
        if not root: return []
        from collections import deque
        res,queue = [],deque()
        queue.append(root)     
        while queue:
            level_list = []
            for _ in range(len(queue)):
            
                node = queue.popleft()
                level_list.append(node.val)
                if node.left:queue.append(node.left)
                if node.right:queue.append(node.right)
            res.append(level_list)
        return res
关注
打赏
1665674626
查看更多评论
立即登录/注册

微信扫码登录

0.0367s