leetcode-二叉树的后序遍历

145. 二叉树的后序遍历

迭代法

# 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 postorderTraversal(self, root: Optional[TreeNode]) -> List[int]:res = []def helper(root, res):if root:helper(root.left, res)helper(root.right, res)res.append(root.val)helper(root, res)return res

迭代法

先序遍历是中左右,后续遍历是左右中,那么我们只需要调整一下先序遍历的代码顺序,就变成中右左的遍历顺序,然后在反转res数组,输出的结果顺序就是左右中了

# 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 postorderTraversal(self, root: Optional[TreeNode]) -> List[int]:if not root:return []stack, res = [root], []while stack:node = stack.pop()res.append(node.val)if node.left:stack.append(node.left)if node.right:stack.append(node.right)return res[::-1]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/641090.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ORA-01033: ORACLE initialization or shutdown in progress---惜分飞

客户反馈数据库使用plsql dev登录报ORA-01033: ORACLE initialization or shutdown in progress的错误 出现该错误一般是由于数据库没有正常open成功,查看oracle 告警日志发现 Mon Jan 22 16:55:50 2024 Database mounted in Exclusive Mode Lost write protection disabled …

React16源码: React中的completeWork中对不同类型节点处理的源码实现

completeWork 1 )概述 在 completeUnitOfWork 当中,在节点是正常渲染没有任何出错的情况下会去调用 completework,对这个节点进行一个完成工作的一系列操作在update各种component的时候,执行了各种获取context相关的内容对于 com…

Oracle动态执行sql和其中clob字段的运用

在Oracle中,您可以使用动态SQL来执行SQL语句,这些语句在运行时构建和执行。以下是一些执行动态SQL的方法: 使用PL/SQL的EXECUTE IMMEDIATE: EXECUTE IMMEDIATE 允许您在运行时构建并执行SQL或PL/SQL语句。 DECLARE l_sql VARCHAR2(1000); B…

Unity SRP 管线【第五讲:URP烘培光照】

本节,我们将跟随数据流向讲解UEP管线中的烘培光照。 文章目录 一、URP烘培光照1. 搭建场景2. 烘培光照参数设置MixedLight光照设置:直观感受 Lightmapping Settings参数设置: 3. 我们如何记录次表面光源颜色首先我们提取出相关URP代码&#…

企业数字档案馆的构成要素

企业数字档案馆的构成要素包括以下几个方面: 1. 系统平台:企业数字档案馆需要有一个稳定的系统平台,用于存储、管理和检索档案信息。这个平台可以是基于云计算、数据库或其他技术的,能够支持大容量的数据存储和快速的检索功能。 2…

Cookie在客户机上是如何存储的如何获取如何保密

Cookie在客户机上的存储和获取方式如下: 存储方式:当用户访问网站时,服务器可以通过设置Cookie来存储数据。这些数据以文件的形式存储在客户端计算机的浏览器上。每个Cookie都有一个唯一的名称和值,可以包含各种信息,…

设计模式二(工厂模式)

本质:实例化对象不用new,用工厂代替,实现了创建者和调用者分离 满足: 开闭原则:对拓展开放,对修改关闭 依赖倒置原则:要针对接口编程 迪米特原则:最少了解原则,只与自己直…

WPF行为

背景:实现按钮鼠标移动到上方有点交互效果或变一下有阴影。这样使用触发器就行了,但是如果是每个控件都有效果的话使用行为更加合适 1、下载NuGet包:Microsoft.xaml.behavior.wpf 2、创建行为类EffectBehavior,对Behavior进行重写…

Unity—配置lua环境变量+VSCode 搭建 Lua 开发环境

每日一句:保持须臾的浪漫,理想的喧嚣,平等的热情 Windows 11下配置lua环境变量 一、lua-5.4.4版本安装到本地电脑 链接:https://pan.baidu.com/s/14pAlOjhzz2_jmvpRZf9u6Q?pwdhd4s 提取码:hd4s 二、高级系统设置 此电…

网站高并发怎么应对?

随着互联网的快速发展,网站高并发已成为一个普遍存在的问题。高并发请求意味着在短时间内有大量用户同时访问一个网站,这给服务器和系统带来了巨大的压力,可能导致一系列的危害。 一、网站高并发的危害 1.性能下降:高并发请求会…

笨蛋学设计模式行为型模式-中介者模式【24】

行为型模式-中介者模式 8.11中介者模式8.11.1概念8.11.2场景8.11.3优势 / 劣势8.11.4模式可分为8.11.5模式8.11.6实战8.11.6.1题目描述8.11.6.2输入描述8.11.6.3输出描述8.11.6.4代码 8.11.7总结 8.11中介者模式 8.11.1概念 ​ 中介者模式通过引入一个中介者对象来封装一组对…

P9232 [蓝桥杯 2023 省 A] 更小的数

[蓝桥杯 2023 省 A] 更小的数 终于本弱一次通关了一道研究生组别的题了[普及/提高−] 一道较为简单的双指针题,但一定有更好的解法. 题目描述 小蓝有一个长度均为 n n n 且仅由数字字符 0 ∼ 9 0 \sim 9 0∼9 组成的字符串,下标从 0 0 0 到 n − 1 n-1 n−1&a…

C++ //练习 2.35 判断下列定义推断出的类型是什么,然后编写程序进行验证。

C Primer(第5版) 练习 2.35 练习 2.35 判断下列定义推断出的类型是什么,然后编写程序进行验证。 const int i 42; auto j i; const auto &k i; auto *p &i; const auto j2 i, &k2 i;环境:Linux Ubuntu&#x…

HarmonyOS鸿蒙学习基础篇 - 运行第一个程序 Hello World

下载与安装DevEco Studio 古话说得好,“磨刀不误砍柴工”,对于HarmonyOS应用开发,我们首先得确保工具齐全。这就好比要进行HarmonyOS应用开发,我们需要确保已经安装了DevEco Studio,这是HarmonyOS的一站式集成开发环境…

企业网架构

企业网架构 局域网通信不同网段 局域网通信 MAC地址:硬件地址,固定在网卡上的地址(唯一标识一个网卡),确定网络设备位置的,数据链路层。一个设备可以有多个网卡,每一个网卡都需要一个唯一MAC。ARP协议:通过目的IP&…

leetcode刷题(剑指offer) 287.寻找重复数

287.寻找重复数 给定一个包含 n 1 个整数的数组 nums ,其数字都在 [1, n] 范围内(包括 1 和 n),可知至少存在一个重复的整数。 假设 nums 只有 一个重复的整数 ,返回 这个重复的数 。 你设计的解决方案必须 不修改…

LeetCode 46. 全排列

46. 全排列 给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1: 输入:nums [1,2,3] 输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]示例 2: 输入&#…

Ddosify 作为压测工具的使用指南

文章目录 1. 写在最前面1.1 Kubernetes 监控1.2 Performance Testing 2. 命令行安装 & 使用2.1 安装2.2 使用2.2.1 默认的例子2.2.2 定制的例子 3. Dashboard 安装 & 使用3.1 安装3.2 使用3.2.1 简单使用3.2.3 依赖的服务介绍 4. 碎碎念5. 参考资料 1. 写在最前面 由于…

Docker-Jenkins编译android-app的两种方案

Docker-Jenkins编译android-app的两种方案 android开发使用jenkins编译,自动集成修改点/自动命名/自动备份,将修改的apk发布到测试服务器发布网盘,而不需要用通讯工具传来传去。 jenkins用在互联网开发编译比较常见,如果android开…

C++ //练习 2.40 根据自己的理解写出Sales_data类,最好与书中的例子有所区别。

C Primer(第5版) 练习 2.40 练习 2.40 根据自己的理解写出Sales_data类,最好与书中的例子有所区别。 环境:Linux Ubuntu(云服务器) 工具:vim 代码块 struct Sales_data{std::string bookNo;…