LeetCode题目99:图解中叙遍历、Morris遍历实现恢复二叉树搜索树【python】

题目描述

给你二叉搜索树的根节点 root,该树中的恰好两个节点的值被错误地交换。请在不改变其结构的情况下,恢复这棵树。

输入格式
  • root:二叉树的根节点。
输出格式
  • 不需要返回值,直接在原树上进行恢复。

示例

示例 1
输入: [1,3,null,null,2]
输出: [3,1,null,null,2]
解释: 3 和 1 被错误交换。
示例 2
输入: [3,1,4,null,null,2]
输出: [2,1,4,null,null,3]
解释: 2 和 3 被错误交换。

方法一:中序遍历和交换

解题步骤
  1. 中序遍历:使用中序遍历找到两个错误的节点。
  2. 节点交换:找到两个不符合中序递增顺序的节点后,交换它们的值。
完整的规范代码
class TreeNode:def __init__(self, val=0, left=None, right=None):self.val = valself.left = leftself.right = rightdef recoverTree(root):"""使用中序遍历恢复二叉搜索树:param root: TreeNode, 二叉搜索树的根节点"""stack = []x = y = prev = Nonewhile stack or root:while root:stack.append(root)root = root.leftroot = stack.pop()if prev and root.val < prev.val:y = rootif not x:x = prevelse:breakprev = rootroot = root.right# 交换两个节点的值if x and y:x.val, y.val = y.val, x.val# 示例调用
root = TreeNode(1, TreeNode(3, None, TreeNode(2)))
recoverTree(root)
算法分析
  • 时间复杂度:(O(n)),需要遍历所有节点。
  • 空间复杂度:(O(h)),其中 (h) 是树的高度,用于存储栈。
中序遍历的 ASCII 图解

假设我们有一个二叉树,其中两个节点值被错误交换,例如树结构为:

    3/ \1   4/2

中序遍历应为 [1, 3, 4, 2],但正确的排序应为 [1, 2, 3, 4],其中 4 和 2 被错误地交换。

开始中序遍历:访问节点 3|   去左 -> 访问节点 1|   |   打印节点 1|   |   返回节点 3|   打印节点 3|   去右 -> 访问节点 4|   |   去左 -> 访问节点 2|   |   |   打印节点 2|   |   |   返回节点 4|   |   打印节点 4|   |   结束

方法二:Morris 中序遍历

解题步骤
  1. Morris 遍历:这种遍历方式不需要额外的空间,通过修改树的结构实现。
  2. 找出并交换错误节点:在遍历过程中寻找顺序错误的节点,并在遍历结束后交换它们的值。
完整的规范代码
def recoverTree(root):x = y = prev = pred = Nonewhile root:if root.left:pred = root.leftwhile pred.right and pred.right != root:pred = pred.rightif not pred.right:pred.right = rootroot = root.leftelse:if prev and root.val < prev.val:y = rootif not x:x = prevprev = rootpred.right = Noneroot = root.rightelse:if prev and root.val < prev.val:y = rootif not x:x = prevprev = rootroot = root.rightif x and y:x.val, y.val = y.val, x.val# 示例调用
root = TreeNode(1, TreeNode(3, None, TreeNode(2)))
recoverTree(root)
算法分析
  • 时间复杂度:(O(n)),虽然是 Morris 遍历,每个节点最多被访问两次。
  • 空间复杂度:(O(1)),不使用额外空间,除非修改了树的结构。

不同算法的优劣势对比

特征方法一:中序遍历方法二:Morris 遍历
时间复杂度(O(n))(O(n))
空间复杂度(O(h))(O(1))
优势易于理解和实现不需要额外空间
劣势空间复杂度较高修改了树的结构
Morris 遍历的 ASCII 图解

使用同样的树结构进行 Morris 遍历,我们通过修改树的结构来避免使用额外的空间。

开始Morris遍历:访问节点 3|   左节点存在,找到前驱(节点 1)|   |   前驱的右节点为空,链接到当前节点|   |   去左|   访问节点 1|   |   前驱是节点 3,断开链接,打印节点 1|   |   返回节点 3,打印节点 3|   去右 -> 访问节点 4|   |   左节点存在,找到前驱(节点 2)|   |   |   前驱的右节点为空,链接到当前节点|   |   |   去左|   |   访问节点 2|   |   |   前驱是节点 4,断开链接,打印节点 2|   |   |   返回节点 4,打印节点 4|   |   结束

应用示例

这些方法可用于数据库中维护数据索引的完整性、修复由于错误操作或系统故障导致数据结构损坏的情况,或者在进行复杂的数据操作前验证数据的一致性。

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

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

相关文章

机器学习周记(第三十七周:语义分割)2024.4.29~2024.5.5

目录 摘要 ABSTRACT 1 DeepLabV3 1.1 空间金字塔池化&#xff08;ASPP&#xff09; 1.2 解码器&#xff08;Decoder&#xff09; 1.3 Xception 2 相关代码 摘要 DeepLabV3 是由Google Brain团队开发的深度学习模型&#xff0c;专注于语义分割任务。它采用深度卷积神经网…

QtWindows任务栏

目录 引言任务栏进度右键菜单缩略图工具栏完整代码 引言 针对Windows系统的任务栏&#xff0c;Qt基于系统的原生接口封装有一些非常见类&#xff0c;如QWinTaskbarButton、QWinTaskbarButton、QWinThumbnailToolBar等&#xff0c;用于利用工具栏提供更多的信息&#xff0c;诸如…

【CTF Web】XCTF GFSJ0482 weak_auth Writeup(弱口令+密码爆破)

weak_auth 小宁写了一个登陆验证页面&#xff0c;随手就设了一个密码。 解法 随便输入一些字符&#xff0c;提示以 admin 登录。 使用 Burp 抓包。 导入密码字典。 进行爆破。 得到密码。 账号&#xff1a;admin 密码&#xff1a;123456取得 flag。 Flag cyberpeace{42c9664…

Servlet框架

简介 Servlet是运行在web服务器或应用服务器上的程序&#xff0c;他是作为来自web浏览器或其他http客户端的请求和HTTP服务器上的数据库或应用程序之间的中间层。 使用Servlet可以手机来自网页表单的用户输入&#xff0c;呈现来自数据库或者其他源记录&#xff0c;还可以动态创…

解决网络ping不通问题

网络ping不通可能有多种原因&#xff0c;以下是一些常见的解决方法&#xff1a; 1. 检查IP地址和域名&#xff1a;确保你使用的是正确的IP地址或者域名来ping目标设备。如果IP地址或者域名错误&#xff0c;ping请求将无法到达目标设备。 2. 检查网络连接&#xff1a;首先确保…

【LeetCode刷题】153. 寻找旋转排序数组中的最小值

1. 题目链接2. 题目描述3. 解题方法4. 代码 1. 题目链接 153. 寻找旋转排序数组中的最小值 2. 题目描述 3. 解题方法 根据题目分析&#xff0c;可以明确一点&#xff0c;无论该数组如何旋转&#xff0c;都会有这样的一个性质&#xff0c;就是nums[0] > nums[n-1]&#xf…

RK3568 学习笔记 : u-boot 千兆网络无法 ping 通PC问题的解决方法二

参考 RK3568 学习笔记 : u-boot 千兆网络无法 ping 通PC问题的解决 前言 rk3568 rockchip 提供的 u-boot&#xff0c;默认的设备树需要读取 单独分区 resouce.img 镜像中的 设备树文件&#xff0c;也就是 Linux 内核的设备树 dtb 文件&#xff0c;gmac 网络才能正常的 ping 通…

STM32F1之FLASH闪存

目录 1. 简介 2. 闪存模块组织 3. FLASH基本结构 4. FLASH解锁 5. 使用指针访问存储器 6. 程序存储器全擦除 7. 程序存储器页擦除 8. 程序存储器编程 9. 选项字节 1. 简介 STM32F1系列的FLASH包含程序存储器、系统存储器和选项字节三个部分&#xff0c;通过…

2024,AI手机“元年”? | 最新快讯

文 | 伯虎财经&#xff0c;作者 | 铁观音 2024年&#xff0c;小米、荣耀、vivo、一加、努比亚等品牌的AI手机新品如雨后春笋般涌现。因此&#xff0c;这一年也被业界广泛视为AI手机的“元年” 试想&#xff0c;当你轻触屏幕&#xff0c;你的手机不仅响应你的指令&#xff0c;更…

C++项目(通讯录管理系统)

系统需求 通讯录是一个可以记录亲人、好友信息的工具。 本教程主要利用C来实现一个通讯录管理系统 系统中需要实现的功能如下: 添加联系人:向通讯录中添加新人&#xff0c;信息包括(姓名、性别、年龄、联系电话、家庭住址)最多 记录1000人 显示联系人:显示通讯录中所有联系人…

【Android】Android应用性能优化总结

AndroidApp应用性能优化总结 最近大半年的时间里&#xff0c;大部分投在了某国内新能源汽车的某款AndroidApp开发上。 由于该App是该款车上&#xff0c;常用重点应用。所以车厂对应用性能的要求比较高。 主要包括&#xff1a; 应用冷启动达到***ms。应用热(温)启动达到***ms应…

RK3568笔记二十四:基于Flask的网页监控系统

若该文为原创文章&#xff0c;转载请注明原文出处。 此实验参考 《鲁班猫监控检测》&#xff0c;原代码有点BUG&#xff0c;已经下载不了。2. 鲁班猫监控检测 — [野火]嵌入式AI应用开发实战指南—基于LubanCat-RK系列板卡 文档 (embedfire.com) 一、简介 记录简单的摄像头监…

易语言IDE界面美化支持库

易语言IDE界面美化支持库 下载下来可以看到&#xff0c;是一个压缩包。 那么&#xff0c;怎么安装到易语言中呢&#xff1f; 解压之后&#xff0c;得到这两个文件。 直接将clr和lib丢到易语言安装目录中&#xff0c;这样子就安装完成了。 打开易语言&#xff0c;在支持库配置…

在营销的世界,你一定要记住:营满,则销

营销的世界中,有一个非常重要的一件事,这几个字一定要记住: 营满,则销;营未满,则不销。 你有没有把握,这是一个没办法可以复杂的东西,真得看营销人的直觉,营跟销是独立的两件事,营在营势,销是自然而然的。这里, 什么样的客户,看到什么样的产品。会有什么样的抗…

HCIP的学习(11)

OSPF的LSA详解 LSA头部信息 ​ [r2]display ospf lsdb router 1.1.1.1----查看OSPF某一条LSA的详细信息&#xff0c;类型以及LS ID参数。 链路状态老化时间 指一条LSA的老化时间&#xff0c;即存在了多长时间。当一条LSA被始发路由器产生时&#xff0c;该参数值被设定为0之后…

32 OpenCV Harris角点检测

文章目录 cornerHarris 算子示例 角点检测 cornerHarris 算子 void cv::cornerHarris ( InputArray src,OutputArray dst,int blockSize,int ksize,double K,int borderType BORDER_DEFAULT) src:待检测Harris角点的输入图像&#xff0c;图像必须是CV 8U或者CV 32F的单通道…

Ansible——lookup,过滤器

文章目录 Ansible——lookup,过滤器lookup读取文件lookup生成随机密码lookup读取环境变量lookup读取Linux命令的执行结果lookup读取template变量替换后的文件lookup读取配置文件lookup读取DNS解析的值 过滤器过滤器使用的位置过滤器对普通变量的操作过滤器对文件路径的操作过滤…

QSqlDatabase的数据库路径或名称问题

在Qt的数据库编程中&#xff0c;先是设置数据库的类型&#xff0c;然后是设置数据库文件的路径&#xff0c;或者数据库名称。若有数据库的用户名、密码&#xff0c;则分别调用setUserName(“”)、setPassword(“”)来设置用户名和密码&#xff1b;若没有&#xff0c;则省略用户…

Maven 在项目的 pom.xml 文件中 指定 阿里云的景象仓库

配置 在 项目的 pom.xml 文件中添加如下配置即可 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation&…

【Unity】位图字体制作工具:蒲公英

一般来讲&#xff0c;如果需要制作位图字体&#xff0c;一般是使用 BMFont 这种第三方工具&#xff1a;BMFont - AngelCode.comhttp://www.angelcode.com/products/bmfont/ 然而这个工具对于非程序员来说&#xff0c;操作起来较为繁琐困难。每次美术修改了字体之后&…