当前位置: 首页 > article >正文

【leetcode100】二叉树的层序遍历

1、题目描述

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

示例 1:

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

2、初始思路

2.1 思路

层序遍历也就是广序优先遍历,保存每层的信息。

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:
    def levelOrder(self, root: Optional[TreeNode]) -> List[List[int]]:
        if not root:
            return []
        queue = collections.deque()
        res = []
        queue.append(root)
        while queue:
            tmp = []
            for _ in range(len(queue)):
                node = queue.popleft()
                tmp.append(node.val)
                if node.left:
                    queue.append(node.left)
                if node.right:
                    queue.append(node.right)
            res.append(tmp)
        return res

3 总结--collections.deque()

queue = collections.deque() 是 Python 中创建双端队列(deque)的语句。deque 是 collections 模块提供的一个数据结构,支持高效的两端操作。

解释:
collections.deque(): 创建一个空的双端队列。

queue: 变量名,用于引用这个双端队列。

特点:
高效的两端操作: 可以在队列的头部和尾部快速进行添加或删除操作,时间复杂度为 O(1)。

线程安全: 适用于多线程环境。

灵活: 可以用作栈或队列。

常用操作:

#添加元素:

queue.append(x)#在右端添加元素

queue.appendleft(x)#在左端添加元素

#删除元素:

queue.pop()#移除并返回右端元素。

queue.popleft()#移除并返回左端元素。
#其他操作:

queue.extend(iterable)#在右端扩展多个元素。
queue = collections.deque([1, 2, 3])
queue.extend([4, 5, 6])  # 在右端扩展元素
print(queue)  # 输出: deque([1, 2, 3, 4, 5, 6])

queue.extendleft(iterable)#在左端扩展多个元素。
queue = collections.deque([1, 2, 3])
queue.extendleft([4, 5, 6])  # 在左端扩展元素
print(queue)  # 输出: deque([6, 5, 4, 1, 2, 3])
#[4, 5, 6] 被逆序添加到左端,因此 6 在最前面。

queue.rotate(n)#旋转队列,正数向右,负数向左。
queue = collections.deque([1, 2, 3, 4, 5])
# 向右旋转 2 步
queue.rotate(2)
print(queue)  # 输出: deque([4, 5, 1, 2, 3])
# 解释: 最后两个元素 [4, 5] 移动到了队列头部。
# 向左旋转 3 步
queue.rotate(-3)
print(queue)  # 输出: deque([2, 3, 4, 5, 1])
# 解释: 前三个元素 [4, 5, 1] 移动到了队列尾部。


http://www.kler.cn/a/519476.html

相关文章:

  • 瑞芯微方案:RV1126定制开发板方案定制
  • Mono里运行C#脚本36—加载C#类定义的成员变量和方法的数量
  • 人格分裂(交互问答)-我想懂Elasticsearch
  • 安宝特方案 | AR在供应链管理中的应用:提升效率与透明度
  • 分布式微服务系统简述
  • StarRocks BE源码编译、CLion高亮跳转方法
  • Elasticsearch中的度量聚合:深度解析与实战应用
  • mock可视化生成前端代码
  • javascript-es6 (一)
  • 【Vim】Vim 中将文件内容复制到系统剪切板的方法
  • 基于Oracle 19C的ADVM与ACFS标准化实施文档
  • Python Pandas数据清洗与处理
  • RabbitMQ---面试题
  • Pyecharts图表交互功能提升
  • vue3+elementPlus之后台管理系统(从0到1)(day4-完结)
  • 在Ubuntu上安装RabbitMQ教程
  • Go语言快速开发入门
  • 微信开发者工具的快捷键
  • ray.rllib-入门实践-12:自定义policy
  • Maui学习笔记-SignalR简单介绍
  • MySQL中的读锁与写锁:概念与作用深度剖析
  • 延迟之争:LLM服务的制胜关键
  • Linux系统之gzip命令的基本使用
  • C++ 与机器学习:构建高效推理引擎的秘诀
  • Gary Marcus对2025年AI的25项预测:AGI的曙光仍未到来?
  • C语言I/O请用递归实现计算 :1 + 1/3 - 1/5 + 1/7 - 1/9 + .... 1/n 的值,n通过键盘输入