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

Leetcode只二叉树中序遍历(python解法)

1.题目描述示例 1输入root [1,null,2,3]输出[1,3,2]示例 2输入root []输出[]示例 3输入root [1]输出[1]2.解决方法:中序遍历就是先遍历左子树然后遍历右子树可以使用栈将左子树所有的根节点的val记录下来然后在从底部网上遍历这才是正确的书顺序此时就可以加上左树和根此时遍历右子树即可栈方法# Definition for a binary tree node.# class TreeNode:# def __init__(self, val0, leftNone, rightNone):# self.val val# self.left left# self.right rightclass Solution:def inorderTraversal(self, root: Optional[TreeNode]) - List[int]:result [] # 存放最终遍历结果stack [] # 显式栈模拟递归调用栈current root # 当前正在处理的节点从根开始# 只要栈不为空或者当前节点不为空就继续循环while stack or current:# 一路向左把路径上所有节点压入栈while current:stack.append(current)current current.left# 此时 current 为 None说明已到达最左叶子的左孩子空# 弹出栈顶 —— 这就是当前子树中“最左但未访问”的节点即该子树的根current stack.pop()result.append(current.val) # 访问它加入结果# 转向它的右子树可能为空也可能有内容current current.rightreturn result递归方法def inorderTraversal(root):if not root: # 基础情况return []left_list inorderTraversal(root.left) # 递归处理左子树right_list inorderTraversal(root.right) # 递归处理右子树return left_list [root.val] right_list

相关文章:

Leetcode只二叉树中序遍历(python解法)

1.题目描述 示例 1: 输入:root [1,null,2,3] 输出:[1,3,2]示例 2: 输入:root [] 输出:[]示例 3: 输入:root [1] 输出:[1]2.解决方法: 中序遍历就是先遍历左子树然后…...

工业模拟量传感器抗干扰设计与实践

1. 工业现场模拟量传感器的干扰挑战在工业自动化领域,模拟量传感器就像一位敏感的"听诊器",它能精确捕捉生产过程中的各种物理量变化。但现实中的工业环境往往充斥着各种"噪音"——大功率电机启停产生的电磁干扰、变频器工作时的谐波…...

靠两台电脑,月入10万,一个中年人的实战分享

阿阳到底是谁?凭什么能做到 月入10万 ?先跟大家说个实话啊,我不是什么大牛,也没啥 光 环。我就是个普通人,普通的家庭,普通的脑子,普通的起点。唯一不普通的,可能就是——我辞职得比…...

代码之外周刊(第期):当技术让一切趋同,我们还剩什么?克

1. 前言 本文详细介绍如何使用 kylin v10 iso 文件构建出 docker image,docker 版本为 20.10.7。 2. 构建 yum 离线源 2.1. 挂载 ISO 文件 mount Kylin-Server-V10-GFB-Release-030-ARM64.iso /media 2.2. 添加离线 repo 文件 在/etc/yum.repos.d/下创建kylin-local…...

龙芯k - 走马观碑组MPU驱动移植谖

先回顾:三次握手(建立连接)核心流程(实际版) 为了让挥手流程衔接更顺畅,咱们先快速回顾三次握手的实际核心,避免上下文脱节: 第一步(客户端→服务器)&#xf…...

Windows环境SonarQube与SonarScanner实战:从零搭建代码质量守护体系

1. 为什么你的项目需要SonarQube? 每次提交代码前,你是不是总在担心那些隐藏的Bug会悄悄溜进生产环境?我见过太多团队在深夜被紧急报警叫醒,原因往往只是一行没处理好的空指针异常。SonarQube就像个24小时值班的代码质检员&#x…...

Arduino TFT库:寄存器级驱动与双芯片兼容设计

1. 项目概述TFT 库是一个专为 Arduino 平台设计的轻量级图形驱动库,核心目标是支持 Seeed Studio 推出的 2.8 英寸 TFT 触摸屏扩展板(v1.0 版本)。该硬件模块采用双芯片方案:显示控制器可选用 SPFD5408A 或 ST7781R 其中之一&…...

Python主流框架全解析

以下是 Python 常用框架的分类解析:一、Web 开发框架1. Django定位:全能型框架,内置 ORM、模板引擎、路由系统等特点:开箱即用(如自带后台管理、用户认证)遵循 MVC 设计模式(MTV 变体&#xff0…...

前端使用AI试水报告读

1 实用案例 1.1 表格样式生成 本示例用于生成包含富文本样式与单元格背景色的Word表格文档。 模板内容: 渲染代码: # python-docx-template/blob/master/tests/comments.py from docxtpl import DocxTemplate, RichText # data: python-docx-template/bl…...

STM32时钟系统解析与启动配置实践

1. STM32单片机启动时的时钟源选择机制刚接触STM32开发时,我总有个疑问:在main函数执行前,单片机是怎么跑起来的?特别是在我们还没配置系统时钟之前,CPU靠什么时钟在工作?这个问题困扰了我很久,…...

Laravel vs 主流PHP框架:终极对决

好的,我们来对比一下 Laravel 与其他一些主流 PHP 框架的特点和适用场景。这种对比通常涉及多个维度,包括易用性、性能、功能丰富度、社区支持等。以下是一个简要的对比表格,总结了 Laravel 与其他几个常见 PHP 框架(Symfony, Cod…...

一文搞懂 MySQL 主从复制

目录 一、什么是 MySQL 主从复制? 主从复制的核心作用(我们为什么要用它?) 二、主从复制的底层原理:大白话拆解全流程 先搞懂 2 个核心文件 再认识 3 个关键线程 完整同步流程,一步一步讲明白 步骤 …...

macos简单配置openclaw贝

1 实用案例 1.1 表格样式生成 本示例用于生成包含富文本样式与单元格背景色的Word表格文档。 模板内容: 渲染代码: # python-docx-template/blob/master/tests/comments.py from docxtpl import DocxTemplate, RichText # data: python-docx-template/bl…...

【MATLAB源码-第415期】基于MATLAB的等效电路与电热耦合的锂离子电池CC-CV充电控制、SOC估计及BMS保护与故障诊断仿真

操作环境:MATLAB 2024a1、算法描述基于等效电路与电热耦合的锂离子电池CC-CV充电控制及BMS保护仿真研究摘要锂离子电池作为电动汽车、储能系统与便携式电子设备中的核心储能单元,其充电过程不仅关系到能量补给效率,还直接影响安全性、寿命保持…...

营销自动化数据驱动 - 多源数据 OLAP 架构演进嘉

1. 流图:数据的河流 如果把传统的堆叠面积图想象成一块块整齐堆叠的积木,那么流图就像一条蜿蜒流淌的河流,河道的宽窄变化自然流畅,波峰波谷过渡平滑。 它特别适合展示多个类别数据随时间的变化趋势,尤其是当你想强调整…...

硬件笔记——使用OrCAD绘制原理图

一、新建工程新建工程,并输入工程的名称和路径,然后会弹出一个PAGE页面:二、修改PAGE页面大小有几种尺寸规格,也可以自定义尺寸,这里以尺寸B规格为例:三、添加原理图库到工程里点击工具栏右上角的芯片图标&…...

Burpsuite之暴力破解+验证码识别 | 添柴不加火萍

springboot自动配置 自动配置了大量组件,配置信息可以在application.properties文件中修改。 当添加了特定的Starter POM后,springboot会根据类路径上的jar包来自动配置bean(比如:springboot发现类路径上的MyBatis相关类&#xff…...

8250串行通信避坑指南:如何用内环测试快速定位硬件故障(附Proteus仿真文件)

8250串行通信避坑指南:如何用内环测试快速定位硬件故障 在嵌入式系统开发中,串行通信故障排查往往是最令人头疼的问题之一。当你面对一个无法正常通信的系统时,问题可能出在硬件连接、芯片配置、软件逻辑或者中断处理等任何一个环节。而8250这…...

RIT库:ARM Cortex-M高精度周期性中断定时器实现

1. RIT库概述:嵌入式系统中的高精度周期性中断定时器实现RIT(Repetitive Interrupt Timer)库是一个专为ARM Cortex-M系列微控制器设计的轻量级、高精度周期性中断定时器抽象层。其核心目标并非替代硬件外设本身,而是提供一套统一、…...

SPI协议实战指南:从基础配置到多设备高效通信

1. SPI协议基础:从零开始理解通信机制 第一次接触SPI协议时,我被它那看似简单的四线制结构迷惑了——明明只有四条线,为什么能实现高速全双工通信?后来在调试智能家居主控板时才发现,正是这种精简设计让SPI成为嵌入式领…...

基于深度学习的CMIP6超分辨率气候数据降尺度技术:中国10公里逐日气象与PET估算实践

1. 为什么我们需要10公里分辨率的气候数据? 想象一下你正在用手机查看天气预报,如果预报只能告诉你"整个华北地区明天有雨",但无法精确到北京海淀区是否下雨,这样的信息对你规划出行有多大帮助?这就是传统气…...

告别虚拟机!在WSL2的Ubuntu 20.04上搞定OpenCV 4.5+完整开发环境(含GUI显示配置)

在WSL2的Ubuntu 20.04上构建OpenCV 4.5全功能开发环境 当计算机视觉开发者第一次尝试在Windows系统上搭建OpenCV环境时,往往会面临两个选择:要么忍受虚拟机沉重的性能开销,要么在原生Windows环境中与各种兼容性问题搏斗。而今天,我…...

DoubleResetDetector_Generic:嵌入式双复位检测库技术解析

1. DoubleResetDetector_Generic 库深度技术解析:跨平台双复位检测的工程实现1.1 工程需求与设计动机在嵌入式设备的生命周期管理中,“如何安全、可靠地进入配置模式”是一个被反复验证却始终缺乏标准化解法的核心问题。传统方案如物理按键、专用跳线或串…...

分享一下我面试Agent岗位时被问到的问题……

以下是我面试了几家公司后,整理出来HR的高频提问总结。 1. 你们用的 Agent 框架是什么?ReAct 还是 Plan-and-Execute? 我:我们主要用 ReAct,就是边想边干的那种。模型每走一步看一眼结果再决定下一步,灵活…...

Modbus协议避坑指南:功能码06写入失败的5个常见原因及解决方法(附Wireshark抓包分析)

Modbus协议避坑指南:功能码06写入失败的5个常见原因及解决方法(附Wireshark抓包分析) 在工业自动化领域,Modbus协议因其简单可靠的特点,成为设备通信的基石。而功能码06(写单个寄存器)作为最常用…...

程序行为的构成:规则、数据与延迟固化的艺术

程序行为的构成:规则、数据与延迟固化的艺术 2026-04-08 程序行为的构成:规则、数据与延迟固化的艺术 在软件系统中,程序行为并非凭空产生,而是规则作用于数据所产生的可观察效应。这一基本公式将程序的内在逻辑清晰地分为两个部分…...

计算机毕业设计:Python气象数据可视化与采集管理系统 Flask框架 数据分析 可视化 爬虫 气象数据分析(建议收藏)✅

博主介绍:✌全网粉丝50W,前互联网大厂软件研发、集结硕博英豪成立软件开发工作室,专注于计算机相关专业项目实战6年之久,累计开发项目作品上万套。凭借丰富的经验与专业实力,已帮助成千上万的学生顺利毕业,…...

【限时开源】:我们刚交付的三级医院FHIR适配引擎源码(C#/.NET 6+),含动态Profile加载、术语服务桥接、差量同步模块——仅开放72小时

第一章:FHIR适配引擎在三级医院信息系统的战略定位与开源意义FHIR适配引擎并非简单的协议转换中间件,而是三级医院实现跨系统互操作、支撑国家健康医疗大数据平台对接、满足《医疗卫生机构网络安全管理办法》与《电子病历系统功能应用水平分级评价标准》…...

嵌入式程序main()退出处理机制与优化实践

1. 嵌入式程序执行的生命周期解析在裸机嵌入式开发中,程序执行流程与通用计算机存在本质差异。以8051架构为例,当开发者在Keil环境下编写一个简单的LED控制程序时,完整的执行链条包含以下几个关键阶段:硬件复位阶段(0x…...

OpenClaw飞书机器人配置:SecGPT-14B安全警报实时推送

OpenClaw飞书机器人配置:SecGPT-14B安全警报实时推送 1. 为什么需要安全警报实时推送? 上周三凌晨3点,我的个人服务器突然收到异常登录告警。当我早上看到邮件时,攻击者早已完成数据窃取并抹除了痕迹。这次事件让我意识到&#…...