★102. 二叉树的层序遍历

102. 二叉树的层序遍历

很巧妙的,又学习了一种层次遍历的方法,就是说根据当前的队列的长度去遍历,遍历的当前队列的长度就是该层次的节点个数。

java 复制代码
/**
 * 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) {
        List<List<Integer>> levelOrderList = new ArrayList<>();
        if(root == null) return levelOrderList;
        Queue<TreeNode> queue = new LinkedList<>();    //用于做队列,遍历整棵树
        List<Integer> list = new ArrayList<>();     // 用于存储用队列遍历树的val
        queue.add(root);
        while(queue.size()!=0) {
        //    System.out.println("当前队列的长度" + queue.size());
            int l = queue.size();
            for(int i=0;i<l; i++) {
                TreeNode front = queue.poll();   //LinkedList的poll方法可以取出第一个元素的值。
                list.add(front.val);
                if(front.left!=null) queue.add(front.left);
                if(front.right!=null) queue.add(front.right);
            }
/*             System.out.print("当前放入的元素为");
            Iterator iterator = list.iterator();
            while(iterator.hasNext()){
                System.out.print(iterator.next() + " ");
            }
            System.out.println(); */
            levelOrderList.add(list);
            list = new ArrayList<Integer>();
        }
        return levelOrderList;
    }
}
相关推荐
静水流深-刘申29 分钟前
算法继续刷起-2025年09月26日
开发语言·c++·算法
木头左1 小时前
跨周期共振效应在ETF网格参数适配中的应用技巧
开发语言·python·算法
顾你&2 小时前
机器学习之无监督学习算法大总结
学习·算法·机器学习
神龙斗士2402 小时前
Java 数组的定义与使用
java·开发语言·数据结构·算法
Y.O.U..2 小时前
力扣HOT100-跳跃游戏II
算法·leetcode
hn小菜鸡2 小时前
LeetCode 3132.找出与数组相加的整数 II
算法·leetcode·职场和发展
微笑尅乐2 小时前
数组模拟加法——力扣66.加一
算法·leetcode·职场和发展
_不会dp不改名_3 小时前
leetcode_146 LRU缓存
算法·leetcode·缓存
Z_z在努力3 小时前
【数据结构】队列(Queue)全面详解
java·开发语言·数据结构
岑梓铭3 小时前
《考研408数据结构》第二章《线性表(顺序表、链表)》复习笔记
数据结构·笔记·考研