LeetCode102 二叉树的层序遍历(即广度优先遍历)

给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。
LeetCode102 二叉树的层序遍历(即广度优先遍历)_第1张图片

示例 1:

输入:root = [3,9,20,null,null,15,7]
输出:[[3],[9,20],[15,7]]
示例 2:

输入:root = [1]
输出:[[1]]
示例 3:

输入:root = []
输出:[]
本人题解

思路

1.题目要求是层序遍历那我们就需要借助队列,而且需要把每层的数据分开存,所有我们需要知道每层树的宽度来控制集合的添加
LeetCode102 二叉树的层序遍历(即广度优先遍历)_第2张图片

代码


```java
class Solution {
    public List<List<Integer>> levelOrder(TreeNode root) {
        List<List<Integer>> result = new ArrayList<>();
        Queue<TreeNode> queue = new ArrayDeque<>();
        if(root ==null)return result;
        else{
            //树根不为空
            queue.offer(root);
        }
        while(!queue.isEmpty()){
            //获取每层树的宽度
            List<Integer> element = new ArrayList<>();
            int len = queue.size();
            for(int i=0;i<len;++i){
                TreeNode curNode = queue.poll();
                
                element.add(curNode.val);
                if(curNode.left!=null) queue.offer(curNode.left);
                if(curNode.right!=null) queue.offer(curNode.right);
            }
            result.add(element);
        }
        return result;
    }
}

你可能感兴趣的:(数据结构,算法题,java,宽度优先,算法,java,数据结构)