2. 二叉树的层序遍历
https://leetcode.cn/problems/binary-tree-level-order-traversal/
给你二叉树的根节点
root,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。示例 1:
输入:root = [3,9,20,null,null,15,7] 输出:[[3],[9,20],[15,7]]
二叉树层次遍历,先建立队列,将根节点放入队列后,出队将出队的节点左右子树放入队列重复上述操作;
- class Solution {
- public List
> levelOrder(TreeNode root) {
- List
> ans=new ArrayList>();
- if(root==null){
- return ans;
- }
- Queue
queue=new ArrayDeque<>(); - queue.offer(root);
- while(!queue.isEmpty()){
- int size=queue.size();
- List
level=new ArrayList<>(); - for(int i=1;i<=size;i++){
- TreeNode cur=queue.poll();
- level.add(cur.val);
- if(cur.left!=null){
- queue.offer(cur.left);
- }
- if(cur.right!=null){
- queue.offer(cur.right);
- }
- }
- ans.add(level);
- }
- return ans;
- }
- }