429. N 叉树的层序遍历 : 树的遍历运用题

简介: 429. N 叉树的层序遍历 : 树的遍历运用题

网络异常,图片无法展示
|


题目描述



这是 LeetCode 上的 429. N 叉树的层序遍历 ,难度为 中等


Tag : 「BFS」、「树」


给定一个 N 叉树,返回其节点值的层序遍历。(即从左到右,逐层遍历)。


树的序列化输入是用层序遍历,每组子节点都由 null 值分隔(参见示例)。


示例 1:


网络异常,图片无法展示
|


输入:root = [1,null,3,2,4,null,5,6]
输出:[[1],[3,2,4],[5,6]]
复制代码


示例 2:


网络异常,图片无法展示
|


输入:root = [1,null,2,3,4,5,null,null,6,7,null,8,null,9,10,null,null,11,null,12,null,13,null,null,14]
输出:[[1],[2,3,4,5],[6,7,8,9,10],[11,12,13],[14]]
复制代码


提示:


  • 树的高度不会超过 1000
  • 树的节点总数在 [0, 10^4][0,104] 之间


BFS



根据题意进行 BFS 即可。


由于我们需要以「层」为单位构建答案,因此在单次 BFS 过程中也按层进行。


代码:


class Solution {
    public List<List<Integer>> levelOrder(Node root) {
        List<List<Integer>> ans = new ArrayList<>();
        Deque<Node> d = new ArrayDeque<>();
        if (root != null) d.addLast(root);
        while (!d.isEmpty()) {
            int size = d.size();
            List<Integer> list = new ArrayList<>();
            while (size-- > 0) {
                Node t = d.pollFirst();
                for (Node node : t.children) d.addLast(node);
                list.add(t.val);
            }
            ans.add(list);
        }
        return ans;
    }
}
复制代码


  • 时间复杂度:O(n)O(n)
  • 空间复杂度:O(n)O(n)


最后



这是我们「刷穿 LeetCode」系列文章的第 No.429 篇,系列开始于 2021/01/01,截止于起始日 LeetCode 上共有 1916 道题目,部分是有锁题,我们将先把所有不带锁的题目刷完。


在这个系列文章里面,除了讲解解题思路以外,还会尽可能给出最为简洁的代码。如果涉及通解还会相应的代码模板。


为了方便各位同学能够电脑上进行调试和提交代码,我建立了相关的仓库:github.com/SharingSour…


在仓库地址里,你可以看到系列文章的题解链接、系列文章的相应代码、LeetCode 原题链接和其他优选题解。

相关文章
二叉树层序遍历及判断完全二叉树
二叉树层序遍历及判断完全二叉树
156 2
树和二叉树(三)
树和二叉树(三)
|
6月前
|
存储
二叉树详解(深度优先遍历、前序,中序,后序、广度优先遍历、二叉树所有节点的个数、叶节点的个数)
二叉树详解(深度优先遍历、前序,中序,后序、广度优先遍历、二叉树所有节点的个数、叶节点的个数)
【霍罗维兹数据结构】二叉树前中后序遍历 | 层序遍历 | 复制二叉树 | 判断两个二叉树全等 | 可满足性问题
【霍罗维兹数据结构】二叉树前中后序遍历 | 层序遍历 | 复制二叉树 | 判断两个二叉树全等 | 可满足性问题
71 0
|
存储
树和二叉树
树和二叉树
68 0
|
6月前
|
数据格式
树结构练习——排序二叉树的中序遍历
树结构练习——排序二叉树的中序遍历
|
存储 人工智能 BI
树和二叉树(一)
树和二叉树(一)
|
存储 算法
二叉树的三序遍历
简要介绍二叉树的三序遍历和重构和代码实现。
102 0
二叉树的实现(前中后层序四种遍历)
二叉树的实现(前中后层序四种遍历)
54 0
二叉树四种遍历的实现
二叉树四种遍历的实现
100 0