剑指 Offer 32 - II. 从上到下打印二叉树 II

剑指 Offer 32 - II. 从上到下打印二叉树 II

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

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

    3
   / \
  9   20
     / \
    15  7

返回其层次遍历结果:

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

提示:

节点总数 <= 1000

一、遍历(BFS)

本题首先要设置一个队列queue,一个list,一个临时列表。

算法流程大概如下:

首先把头结点放入queue,然后再把头结点放入tmp,最后放入list。

然后把左/右节点依次放入队列,再放入tmp,最后再放入list。

大概的思路,就是tmp作为辅助列表,作为队列queue和list的桥梁。

然后什么叫BFS,得解释一下,是二叉数的广度优先搜索的意思。

class Solution {
        public List<List<Integer>> levelOrder(TreeNode root) {
            Deque<TreeNode> queue = new LinkedList<>();
            List<List<Integer>> res = new ArrayList<>();
            //如果头节点不为空,则放入队列queue
            if (root != null) queue.add(root);
            while (!queue.isEmpty()) {
            	//设置一个辅助数组,专门装队列queue的值
                List<Integer> tmp = new ArrayList<>();
                for (int i = queue.size(); i > 0; i--) {
                    TreeNode node = queue.poll();
                    tmp.add(node.val);
                    if (node.left != null) queue.add(node.left);
                    if (node.right != null) queue.add(node.right);
                }
                res.add(tmp);
            }
            return res;
        }
    }

二、递归

class Solution {
        List<List<Integer>> res;
        public List<List<Integer>> levelOrder(TreeNode root) {
            res = new ArrayList<>();
            dfs(0, root);
            return res;
        }

        void dfs(int depth,TreeNode root) {
            if (root == null) return;
            if (depth == res.size()) {//如果数组list的size等于数组里面depth的话,则创建新的一层节点
                res.add(new ArrayList<>());
            }
            //因为dfs(0,root) 所以这个时候是res.get(0).add(root.val),是放入这个数组中第一个数组的头节点
            res.get(depth).add(root.val);
            //递归遍历左右节点
            dfs(depth + 1, root.left);
            dfs(depth + 1, root.right);
        }
    }
posted @ 2021-08-09 23:09  RainsX  阅读(107)  评论(0编辑  收藏  举报