news 2026/5/16 20:00:22

力扣刷题之102、二叉树的层序遍历

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣刷题之102、二叉树的层序遍历

力扣刷题之102、二叉树的层序遍历

题目难度:中等
标签:树、广度优先搜索(BFS)、二叉树


题目描述

给你二叉树的根节点root,返回其节点值的层序遍历。(即逐层地,从左到右访问所有节点)。

示例:

输入root = [3,9,20,null,null,15,7]
输出[[3],[9,20],[15,7]]

输入root = [1]
输出:``

输入root = []
输出[]


解题思路

层序遍历是广度优先搜索(BFS)在二叉树中的典型应用。与深度优先搜索(DFS)不同,BFS 按“层”处理节点,非常适合用队列(Queue)来实现。

核心思想:

  • 使用队列存储待访问的节点。
  • 每次处理当前层的所有节点(通过记录当前队列大小)。
  • 将当前层节点值存入一个列表,再将该列表加入最终结果。
  • 同时把下一层的左右子节点加入队列,为下一轮做准备。

关键点:不能直接用queue.size()作为 for 循环条件,因为队列在循环中会动态变化。必须提前保存当前层的节点数量!


代码实现(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; * } * } */classSolution{publicList<List<Integer>>levelOrder(TreeNoderoot){//创建结果列表,用于存储每一次的节点值List<List<Integer>>result=newArrayList<>();//边界情况:如果根节点为空,直接返回空列表if(root==null){returnresult;}//创建队列,用于BFS的起点Queue<TreeNode>queue=newLinkedList<>();queue.offer(root);//当队列不为空时,继续处理while(!queue.isEmpty()){//获取当前层的节点数量intlevelsize=queue.size();//创建列表存储当前层的所有节点值List<Integer>current=newArrayList<>();//处理当前层的所有节点for(inti=0;i<levelsize;i++){//从队列头部取出一个节点TreeNodeNode=queue.poll();//将当前节点的值添加到当前层的结果列表current.add(Node.val);//如果左子节点存在,将其加入到队列中if(Node.left!=null){queue.offer(Node.left);}//如果右子节点存在,将其加入到队列中if(Node.right!=null){queue.offer(Node.right);}}//将当前层的结果添加到最终结果列表中result.add(current);}//返回层序遍历的结果returnresult;}}

复杂度分析

  • 时间复杂度O(n)
    每个节点被访问一次,n 为树中节点总数。

  • 空间复杂度O(n)
    最坏情况下(完全二叉树),队列中最多存储约 n/2 个节点(最后一层)。


总结

层序遍历是树类问题的基础技能,掌握 BFS + 队列的写法,能轻松应对一大类“按层处理”的题目。所以要记住:先记录当前层大小,再循环处理,这是避免逻辑错误的关键!


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/27 12:34:16

中小企业AI转型首选:Qwen3-14B中型大模型实战应用解析

中小企业AI转型首选&#xff1a;Qwen3-14B中型大模型实战应用解析 在智能客服自动回复用户咨询的瞬间&#xff0c;系统不仅要理解“我的订单还没发”背后的焦急情绪&#xff0c;还要准确识别订单编号、查询物流状态、判断是否需要创建工单——这一连串操作如果依赖人工&#xf…

作者头像 李华
网站建设 2026/4/27 19:37:53

Transformer模型详解系列:Qwen3-VL-8B的跨模态架构解析

Qwen3-VL-8B 跨模态架构深度解析 在智能应用日益依赖多模态理解的今天&#xff0c;如何让AI“看懂”图像并用自然语言准确表达&#xff0c;已成为工业界的核心挑战。传统方案往往依赖复杂的流水线&#xff1a;先目标检测、再OCR识别、最后接NLP模型生成描述——这种割裂式处理不…

作者头像 李华
网站建设 2026/5/12 16:04:49

Straight-Through Estimator (STE)

Straight-Through Estimator (STE)&#xff0c;这是量化神经网络和离散化模型里常用的技巧。

作者头像 李华
网站建设 2026/5/15 20:35:37

进程的描述与控制

目录 进程的概念、组成、特征 进程的状态与转换 进程控制 进程通信&#xff08;IPC&#xff09; 共享存储 消息传递 管道通信 线程的概念与特点 线程的实现方式与多线程模型 线程的实现方式 多线程模型 线程的状态与转换 进程的概念、组成、特征 程序是静态的指令集…

作者头像 李华
网站建设 2026/5/15 0:24:12

ollama下载支持Qwen3-32B吗?最新兼容性测试结果

Ollama 能否运行 Qwen3-32B&#xff1f;实测兼容性与部署全解析 在大模型落地加速的今天&#xff0c;越来越多开发者和企业开始关注一个问题&#xff1a;能否用一条命令就把像 Qwen3-32B 这样的国产高性能大模型跑在本地机器上&#xff1f; Ollama 的出现让这个设想变得触手可…

作者头像 李华
网站建设 2026/5/16 10:06:16

SL3061 DCDC40V耐压输入 输出可调 2.5A电流降压恒压喇叭供电IC

森利威尔原厂SL3061&#xff1a;高性能40V耐压DC-DC降压芯片助力音频系统升级‌在各类电子设备对电源性能要求日益严苛的今天&#xff0c;一款高效、稳定且灵活的电源管理芯片成为设计成功的关键。森利威尔原厂SL3061作为一款专为严苛应用环境打造的开关降压型转换器&#xff0…

作者头像 李华