当前位置 博文首页 > Yawn:Leetcode——二叉树的层序遍历

    Yawn:Leetcode——二叉树的层序遍历

    作者:[db:作者] 时间:2021-08-02 15:46

    1. 二叉树的层序遍历

    给你一个二叉树,请你返回其按 层序遍历 得到的节点值。 (即逐层地,从左到右访问所有节点)。
    在这里插入图片描述

    2. 题解

    解法一:

    BFS解决:广度优先搜索

    这题和剑指 Offer 32——从上到下打印二叉树其实是一样的,只不过上一题返回的是数组,这一题返回的是list。返回数组,我们还要初始化数组,但不知道数组的大小,所以一般是先储存在list中再转化为数组,返回list就比较简单了。
    在这里插入图片描述

    /**
     * Definition for a binary tree node.
     * public class TreeNode {
     *     int val;
     *     TreeNode left;
     *     TreeNode right;
     *     TreeNode() {}
     *     TreeNode(int val) { this.val = val; }
     *     TreeNode(int val, TreeNode left, TreeNode right) {
     *         this.val = val;
     *         this.left = left;
     *         this.right = right;
     *     }
     * }
     */
    class Solution {
        public List<List<Integer>> levelOrder(TreeNode root) {
            if(root == null)
                return new ArrayList<>();
                
            List<List<Integer>> ans = new ArrayList<>();
            Queue<TreeNode> queue = new LinkedList<>(); 
            queue.add(root);
            
            while(!queue.isEmpty()){
                int size = queue.size();
                List<Integer> list = new ArrayList<>();
                while(size > 0){
                    TreeNode node = queue.poll();
                    list.add(node.val);
                    if(node.left != null)
                        queue.add(node.left);
                    if(node.right != null)
                        queue.add(node.right);
                    size--;
                }
                ans.add(list);
            }
            
            return ans;
        }
    }
    
    cs
    下一篇:没有了