0

0

Python树的层序遍历怎么写_利用队列辅助实现二叉树BFS广度遍历

P粉602998670

P粉602998670

发布时间:2026-03-17 10:35:02

|

206人浏览过

|

来源于php中文网

原创

用 collections.deque 实现层序遍历,避免 list.pop(0);入队前判空,用 popleft() 和 append();按层分组需快照 len(queue);递归模拟非真 BFS。

python树的层序遍历怎么写_利用队列辅助实现二叉树bfs广度遍历

collections.deque 做队列,别用 list.pop(0)

层序遍历本质是 BFS,必须保证“先进先出”,而 list.pop(0) 在 Python 中是 O(n) 操作,节点一多就明显卡顿。实际项目里见过 10⁴ 级别节点时慢 3 倍以上。

实操建议:

立即学习Python免费学习笔记(深入)”;

  • 固定用 from collections import deque,初始化写成 queue = deque([root])
  • 每次取队首用 queue.popleft()(O(1)),不是 queue.pop(0)
  • 添加子节点统一用 queue.append(),左右顺序别颠倒(左先右后才符合常规层序)

空节点不入队,但得判断 node 是否为 None

常见错误是把 None 也塞进队列,导致后续 node.leftAttributeError: 'NoneType' object has no attribute 'left'

实操建议:

立即学习Python免费学习笔记(深入)”;

  • 入队前一定检查:if node.left:queue.append(node.left)
  • 进循环第一句就是 node = queue.popleft(),紧接着就 if not node: continue(虽然后者在正确入队逻辑下不会触发,但加了更安心)
  • 如果题目要求输出含 None 的完整层(比如 LeetCode 102 的变体),那另说——但那是显式构造占位,不是把空指针当有效节点塞队列

按层分组返回时,用 len(queue) 快照当前层长度

想返回 [[3], [9, 20], [15, 7]] 这种嵌套列表?不能边遍历边 append 到同一层 list 里,否则搞不清哪几个属于当前层。

AI改图神器
AI改图神器

AI万能图片编辑器,一键抠图,去水印,智能图片美化,照片转漫画,照片变活转视频,图片无损放大,一键背景虚化,位图智能转矢量图

下载

实操建议:

立即学习Python免费学习笔记(深入)”;

  • 每轮循环开始前,记下 level_size = len(queue)
  • for _ in range(level_size): 固定跑完这一层所有节点
  • 避免用时间戳或额外标记节点——没必要,快照长度最直接、无副作用
  • 注意:这个 len(queue) 是进入 for 循环前的值,之后 append 新节点不影响本轮迭代次数

递归写法看似简洁,但不是真层序遍历

有人用 DFS 加个 depth 参数,按深度把节点塞进对应下标列表里,结果输出对了,但执行顺序是深度优先的,根本没用到队列,也不满足 BFS 的访问时序要求。

实操建议:

立即学习Python免费学习笔记(深入)”;

  • 题目明确要求“广度优先”或“使用队列”,这种递归解法就算答案对,也会被判定逻辑错误
  • DFS 模拟层序在极端不平衡树下内存占用反而更高(递归栈深 ≈ 节点数)
  • 真要递归,至少得配合 queue 模拟,但那就绕回迭代了——没优势
事情说清了就结束。真正容易被忽略的是:队列操作的常数性能差异在小数据上看不出,但一旦节点带 payload(比如每个节点存一个大 dict),list.pop(0) 的内存搬移成本会突然暴露。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

java break和continue
java break和continue

本专题整合了java break和continue的区别相关内容,阅读专题下面的文章了解更多详细内容。

262

2025.10.24

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

448

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

606

2023.08.10

空指针异常处理
空指针异常处理

本专题整合了空指针异常解决方法,阅读专题下面的文章了解更多详细内容。

23

2025.11.16

空指针异常处理
空指针异常处理

本专题整合了空指针异常解决方法,阅读专题下面的文章了解更多详细内容。

23

2025.11.16

append用法
append用法

append是一个常用的命令行工具,用于将一个文件的内容追加到另一个文件的末尾。想了解更多append用法相关内容,可以阅读本专题下面的文章。

349

2023.10.25

python中append的用法
python中append的用法

在Python中,append()是列表对象的一个方法,用于向列表末尾添加一个元素。想了解更多append的更多内容,可以阅读本专题下面的文章。

1080

2023.11.14

Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建
Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建

本指南详解Nginx在Windows、macOS及Linux系统的安装全流程。涵盖官方包解压、Homebrew一键部署、APT/YUM源配置及Docker容器化方案。无论新手或开发者,均可快速搭建运行环境,掌握跨平台核心指令,为后续配置与调优奠定坚实基础。

10

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5.1万人学习

SciPy 教程
SciPy 教程

共10课时 | 2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号