★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;
    }
}
相关推荐
星逝*16 小时前
LeetCode刷题-top100( 矩阵置零)
算法·leetcode·矩阵
小江村儿的文杰16 小时前
理解UE4中C++17的...符号及enable_if_t的用法及SFINAE思想
数据结构·c++·ue4
zandy101117 小时前
LLM与数据工程的融合:衡石Data Agent的语义层与Agent框架设计
大数据·人工智能·算法·ai·智能体
max50060017 小时前
本地部署开源数据生成器项目实战指南
开发语言·人工智能·python·深度学习·算法·开源
地平线开发者17 小时前
征程 6E/M|多 camera 场景示例
算法·自动驾驶
源代码•宸18 小时前
Leetcode—721. 账户合并【中等】
c++·经验分享·算法·leetcode·并查集
緈福的街口18 小时前
【leetcode】77.组合
算法·leetcode·职场和发展
NAGNIP18 小时前
深入 vLLM:高性能大模型推理框架解析
算法
JuneXcy18 小时前
字符串(2)
算法
快去睡觉~18 小时前
力扣152:乘积最大子数组
算法·leetcode·职场和发展