相同,对称,平衡,右视图(二叉树)

本篇基于b站灵茶山艾府。

100. 相同的树

给你两棵二叉树的根节点 pq ,编写一个函数来检验这两棵树是否相同。

如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。

示例 1:

img

输入:p = [1,2,3], q = [1,2,3]
输出:true

示例 2:

img

输入:p = [1,2], q = [1,null,2]
输出:false

示例 3:

img

输入:p = [1,2,1], q = [1,1,2]
输出:false

# 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 isSameTree(self, p: Optional[TreeNode], q: Optional[TreeNode]) -> bool:def dfs(p, q):if not p or not q:# 两个节点都为空,返回True,否则返回Falsereturn p == q# 判断两个节点值和左右子树相不相等return p.val == q.val and dfs(p.left, q.left) and dfs(p.right, q.right)return dfs(p, q)


101. 对称二叉树

给你一个二叉树的根节点 root , 检查它是否轴对称。

示例 1:

img

输入:root = [1,2,2,3,4,4,3]
输出:true

示例 2:

img

输入:root = [1,2,2,null,3,null,3]
输出:false

# 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 isSymmetric(self, root: Optional[TreeNode]) -> bool:# 本质上跟判断相同的树一样def dfs(p, q):if not p or not q:return p == q# 唯一不同的就是传入的是左子树的左孩子和右子树的右孩子(左子树的右孩子和右子树的左孩子)来判断return p.val == q.val and dfs(p.left, q.right) and dfs(p.right, q.left)return dfs(root.left, root.right)


110. 平衡二叉树

给定一个二叉树,判断它是否是平衡二叉树

示例 1:

img

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

示例 2:

img

输入:root = [1,2,2,3,3,null,null,4,4]
输出:false

示例 3:

输入:root = []
输出:true

# 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 isBalanced(self, root: Optional[TreeNode]) -> bool:def dfs(node):if not node:# 返回一个元组,第一个值为该树是否为平衡二叉树,第二个值是此树的高度return (True, 0)f1, h1 = dfs(node.left)f2, h2 = dfs(node.right)# 如果左右子树的高度差不超过1且左右子树都是平衡二叉树,返回True,且向上层返回该树的高度return (abs(h1 - h2) <= 1 and f1 and f2, max(h1, h2) + 1)return dfs(root)[0]


199. 二叉树的右视图

给定一个二叉树的 根节点 root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。

示例 1:

输入: root = [1,2,3,null,5,null,4]

输出:[1,3,4]

解释:

img

示例 2:

输入: root = [1,2,3,4,null,null,null,5]

输出:[1,3,4,5]

解释:

img

示例 3:

输入: root = [1,null,3]

输出:[1,3]

示例 4:

输入: root = []

输出:[]


# 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 rightSideView(self, root: Optional[TreeNode]) -> List[int]:def dfs(node, h):if not node:return# 如果首次遇到这个深度,说明是最右边的节点,需要记录高度if h == len(ans):ans.append(node.val)# 从右子树开始遍历dfs(node.right, h + 1)dfs(node.left, h + 1)ans = []dfs(root, 0)return ans


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

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

相关文章

MCU开发学习记录19* - CAN学习与实践(HAL库) - 定时传输、触发传输和请求传输(轮询与中断实现) -STM32CubeMX

名词解释&#xff1a; CAN&#xff1a;Controller Area Network ISO&#xff1a;​International Organization for Standardization ​OSI&#xff1a;​Open Systems Interconnection SOF&#xff1a;​Start Of Frame EOF&#xff1a;​End Of Frame​​ 统一文章结构&…

LEED认证是什么?LEED认证难吗?LEED认证需要准备的资料

LEED&#xff08;Leadership in Energy and Environmental Design&#xff0c;能源与环境设计先锋&#xff09;是由美国绿色建筑委员会&#xff08;USGBC&#xff09;开发的一套全球广泛认可的绿色建筑认证体系&#xff0c;用于评估建筑在设计、施工、运营和维护中的可持续性表…

【ffmpeg】ffprobe基本用法

ffprobe 是 FFmpeg 工具集中的一个强大命令行工具&#xff0c;主要用于分析多媒体文件&#xff08;如视频、音频等&#xff09;的格式和内容信息。它可以提取文件的元数据、编解码器信息、流详情、帧信息等&#xff0c;而无需对文件进行转码或修改。 基本用法 ffprobe [选项] …

暗黑科技感风格智慧工地监管系统

智慧工地监管系统作为这场变革中的关键力量&#xff0c;正逐渐改变着传统工地的管理模式。今天&#xff0c;就带大家一同领略一款用Axure精心打造的暗黑科技感风格智慧工地监管系统原型&#xff0c;感受科技与建筑碰撞出的奇妙火花。 这款智慧工地监管系统原型采用了极具魅力的…

【软件安装】Windows操作系统中安装mongodb数据库和mongo-shell工具

这篇文章&#xff0c;主要介绍Windows操作系统中如何安装mongodb数据库和mongo-shell工具。 目录 一、安装mongodb数据库 1.1、下载mongodb安装包 1.2、添加配置文件 1.3、编写启动脚本&#xff08;可选&#xff09; 1.4、启动服务 二、安装mongo-shell工具 2.1、下载mo…

CSS:margin的塌陷与合并问题

文章目录 一、margin塌陷问题二、margin合并问题 一、margin塌陷问题 二、margin合并问题

PostgreSQL 数据库备份与恢复

1 逻辑备份(单库) postgres#pg_dump --help 使用方法: pg_dump [选项]... [数据库名字] 一般选项: -f, --fileFILENAME 输出文件或目录名 -F, --formatc|d|t|p 输出文件格式 (c 自定义压缩格式输出, d 目录, tar,p 备份为文本明…

使用 LibreOffice 实现各种文档格式转换(支持任何开发语言调用 和 Linux + Windows 环境)[全网首发,保姆级教程,建议收藏]

以下能帮助你可以使用任何开发语言&#xff0c;在任何平台都能使用 LibreOffice 实现 Word、Excel、PPT 等文档的自动转换&#xff0c;目前展示在 ASP.NET Core 中为 PDF的实战案例&#xff0c;其他的文档格式转换逻辑同理。 &#x1f4e6; 1. 安装 LibreOffice &#x1f427;…

AWS stop/start 使实例存储lost + 注意点

先看一下官方的说明: EC2有一个特性,当执行stop/start操作(注意,这个并不是重启/reboot,而是先停止/stop,再启动/start)时,该EC2会迁移到其它的底层硬件上。 对于实例存储来说,由于实例存储是由其所在的底层硬件来提供的,此时相当于分配到了一块全新的空的磁盘。 但是从…

跨域问题详解

目录 一、什么是跨域问题&#xff1f; 二、跨域问题出现的原因 三、跨域的解决方案 四、结语 在 Web 开发的世界里&#xff0c;当我们尝试通过 AJAX 等技术获取不同源的资源时&#xff0c;常常会遇到 “跨域问题”。这不仅是前端开发者频繁遭遇的技术障碍&#xff0c;也是保…

VSCode 插件 GitLens 破解方法

文章目录 1. 安装指定版本2. 修改插件文件3. 重启 VSCode 1. 安装指定版本 在 VSCode 中打开扩展&#xff08;Ctrl Shift X&#xff09;&#xff0c;搜索 GitLens&#xff0c;右键点击 安装特定版本&#xff0c;在弹出的窗口中选择 17.0.2&#xff0c;然后等待安装完成。 2…

JavaScript的三大核心组成:ECMAScript、DOM与BOM

JavaScript的三大核心组成&#xff1a;ECMAScript、DOM与BOM 在前端开发领域&#xff0c;JavaScript是构建动态网页和交互式应用的核心语言。然而&#xff0c;许多人对JavaScript的组成缺乏清晰的认识。实际上&#xff0c;JavaScript并非单一的语言规范&#xff0c;而是由三个…

JC/T 2490-2019 石灰基单层装饰砂浆检测

石灰基单层装饰砂浆是指由石灰等无机胶凝材料、级配砂、外加剂或无机颜料制成的具有装饰功能的干粉饰面材料。 JC/T 2490-2019石灰基单层装饰砂浆检测项目&#xff1a; 测试项目 测试方法 外观 JC/T 2490 干密度 JC/T 2490 凝结时间 JGJ/T 70 抗折强度 GB/T 17671 抗…

用算法实现 用统计的方式实现 用自然语言处理的方法实现 用大模型实现 专利精益化统计分析

我们可以从算法、统计、自然语言处理&#xff08;NLP&#xff09;和大型语言模型&#xff08;LLM&#xff09;这四个方面&#xff0c;探讨如何实现对专利社区、作者重要性以及共同作者贡献度的分析。 1. 如何体现专利的社区 (社群效应) &#x1f916; 用算法实现 网络分析算法…

深入浅出IIC协议 - 从总线原理到FPGA实战开发 -- 第五篇:多主仲裁与错误恢复

第五篇&#xff1a;多主仲裁与错误恢复 副标题 &#xff1a;从总线冲突到故障自愈——构建高可靠I2C系统的终极指南 1. 多主仲裁机制 1.1 仲裁原理与硬件实现 仲裁流程图解 &#xff1a; 仲裁失败处理 &#xff1a; 立即切换为从机模式 监测总线空闲后重试&#xff08;随机…

146. LRU Cache

题目描述 146. LRU Cache 哈希表双向链表 详见代码和注释&#xff1a; class LRUCache { private:int capacity_{0};int size_{0};struct Node{int key{0};int val{0};Node* pre{nullptr};Node* next{nullptr};Node(int k,int v,Node* pr,Node* nex):key(k),val(v),pre(pr),…

docker network 自定义网络配置与管理指南

Docker 自定义网络配置与管理指南 1. 网络基础概念 Docker 网络是容器间通信和与外部世界交互的基础。通过自定义网络&#xff0c;可以实现容器间的隔离、静态 IP 分配和服务发现。 关键术语&#xff1a; 子网(Subnet)&#xff1a;IP 地址的逻辑分组&#xff0c;例如 172.1…

linux strace调式定位系统问题

strace 的基本功能 strace 的主要功能包括&#xff1a; 跟踪系统调用&#xff1a;显示进程执行时调用的系统函数及其参数和返回值。监控信号&#xff1a;记录进程接收到的信号。性能分析&#xff1a;统计系统调用的执行时间和次数。调试支持&#xff1a;帮助定位程序崩溃、性…

告别手抖困扰:全方位健康护理指南

手抖&#xff0c;医学上称为震颤&#xff0c;是常见的身体症状&#xff0c;可能由多种原因引发&#xff0c;了解其成因并采取科学护理措施&#xff0c;对改善症状、维护健康至关重要。 生理性手抖往往因情绪激动、过度劳累、大量饮用咖啡或酒精等引起&#xff0c;这种手抖通常较…

华为2025年校招笔试真题手撕教程(一)

一、题目 输入&#xff1a; 第一行为记录的版本迭代关系个数N&#xff0c;范围是[1&#xff0c;100000]; 第二行到第N1行&#xff1a;每行包含两个字符串&#xff0c;第一个字符串为当前版本&#xff0c;第二个字符串为前序版本&#xff0c;用空格隔开。字符串包含字符个数为…