热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

leetcode99.恢复二叉搜索树/中序遍历

文章目录题目:二叉搜索树中的两个节点被错误地交换。基本思想1:中序遍历题目:二叉搜索树中的两个节点被错误地交换。请在不改变其结构的情况下


文章目录

    • 题目:二叉搜索树中的两个节点被错误地交换。
    • 基本思想1:中序遍历


题目:二叉搜索树中的两个节点被错误地交换。

请在不改变其结构的情况下,恢复这棵树。

示例 1:

输入: [1,3,null,null,2]1/3\2输出: [3,1,null,null,2]3/1\2

示例 2:

输入: [3,1,4,null,null,2]3/ \
1 4/2输出: [2,1,4,null,null,3]2/ \
1 4/3

进阶:


  • 使用 O(n) 空间复杂度的解法很容易实现。
  • 你能想出一个只使用常数空间的解决方案吗?

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/recover-binary-search-tree
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。


基本思想1:中序遍历

二叉搜索树中序遍历的结果一定是升序序列,那么在该题中中序遍历的序列在交换两个元素后,成为升序序列。


  • 首先,对二叉树进行中序遍历,并保存中序遍历的结果序列
  • 寻找结果序列中第一个逆序的元素前面的元素pre
  • 从元素pre一直往后寻找,当找到一个大于该元素的元素temp时,temp前面的元素post就是需要交换的元素
  • 将pre和post这两个元素进行交换

空间复杂度为O(n)的写法
定义一个数组保存中序遍历的顺序

/*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:vector<TreeNode*> vec;void recoverTree(TreeNode* root) {inorder(root);int pre &#61; 0, i;for(i &#61; 1; i < vec.size(); &#43;&#43;i){if(vec[i]->val > vec[pre]->val)&#43;&#43;pre;elsebreak;}for(; i < vec.size(); &#43;&#43;i){if(vec[i]->val > vec[pre]-> val)break;}--i;int t &#61; vec[i]->val;vec[i]->val &#61; vec[pre]->val;vec[pre]->val &#61; t;}void inorder(TreeNode* root){if(root &#61;&#61; NULL)return;inorder(root->left);vec.push_back(root);inorder(root->right);}
};

空间复杂度为O&#xff08;1&#xff09;的写法&#xff1a;
定义两个变量来保存逆序的两个节点

/*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:void recoverTree(TreeNode* root) {TreeNode* pre1 &#61; NULL, *pre2 &#61; NULL;inorder(root, pre1, pre2);int t &#61; pre1->val;pre1->val &#61; pre2->val;pre2->val &#61; t;}void inorder(TreeNode* root, TreeNode* &pre1, TreeNode* &pre2){if(root &#61;&#61; NULL)return;inorder(root->left, pre1, pre2);if(pre1 &#61;&#61; NULL){//root是根节点的情况pre1 &#61; root;}else{if(root->val > pre1->val && (!pre2 || root->val < pre2->val)){pre1 &#61; root;}else if(pre2 &#61;&#61; NULL){//此时找到了第一个需要交换的节点&#xff0c;保存在pre2中pre2 &#61; pre1;pre1 &#61; root;}if((root->val < pre1->val) && (pre2) && (pre2->val > root->val)){//此时找到了第二个需要交换的节点保存在pre1中pre1 &#61; root;}}inorder(root->right, pre1, pre2);}
};

推荐阅读
  • 题面:P3178[HAOI2015]树上操作好像其他人都嫌这道题太容易了懒得讲,好吧那我讲。题解:第一个操作和第二个操作本质上是一样的&# ... [详细]
  • [编程题] LeetCode上的Dynamic Programming(动态规划)类型的题目
    继上次把backTracking的题目做了一下之后:backTracking,我把LeetCode的动态规划的题目又做了一下,还有几道比较难的Medium的题和Hard的题没做出来,后面会继续 ... [详细]
  • 本文详细介绍了如何将After Effects中的动画相机数据导入到Vizrt系统中,提供了一种有效的解决方案,适用于需要在广播级图形制作中使用AE动画的专业人士。 ... [详细]
  • 本文基于《Core Java Volume 2》的内容,深入探讨了网络编程中通过POST方法提交表单数据的技术细节,包括GET与POST方法的区别、POST提交的具体步骤及常见问题处理。 ... [详细]
  • 来自FallDream的博客,未经允许,请勿转载,谢谢。一天一套noi简直了.昨天勉强做完了noi2011今天教练又丢出来一套noi ... [详细]
  • 本文详细介绍了在PHP中如何获取和处理HTTP头部信息,包括通过cURL获取请求头信息、使用header函数发送响应头以及获取客户端HTTP头部的方法。同时,还探讨了PHP中$_SERVER变量的使用,以获取客户端和服务器的相关信息。 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • 微信小程序支付官方参数小程序中代码后端发起支付代码支付回调官方参数文档地址:https:developers.weixin.qq.comminiprogramdeva ... [详细]
  • SQLite是一种轻量级的关系型数据库管理系统,尽管体积小巧,却能支持高达2TB的数据库容量,每个数据库以单个文件形式存储。本文将详细介绍SQLite在Android开发中的应用,包括其数据存储机制、事务处理方式及数据类型的动态特性。 ... [详细]
  • 本文探讨了Web API 2中特性的路由机制,特别是如何利用它来构建RESTful风格的URI。文章不仅介绍了基本的特性路由使用方法,还详细说明了如何通过特性路由进行API版本控制、HTTP方法的指定、路由前缀的应用以及路由约束的设置。 ... [详细]
  • 深入解析轻量级数据库 SQL Server Express LocalDB
    本文详细介绍了 SQL Server Express LocalDB,这是一种轻量级的本地 T-SQL 数据库解决方案,特别适合开发环境使用。文章还探讨了 LocalDB 与其他轻量级数据库的对比,并提供了安装和连接 LocalDB 的步骤。 ... [详细]
  • 本文探讨了如何利用数组来构建二叉树,并介绍了通过队列实现的二叉树层次遍历方法。通过具体的C++代码示例,详细说明了构建及打印二叉树的过程。 ... [详细]
  • 2022年4月15日的算法练习题,包括最长公共子序列和线段树的应用。 ... [详细]
  • 本文介绍了一道来自LeetCode的编程题——拼写单词。题目要求从给定的词汇表中找出可以由指定字母表中的字母拼写出的单词,并计算这些单词的总长度。文章将展示如何通过使用数组替代哈希表来提高算法的执行效率。 ... [详细]
  • 本文介绍了一种使用链剖分(Link-Cut Tree, LCT)来维护动态树结构的方法,特别是如何通过 LCT 来高效地管理子树的信息,如子树大小等。 ... [详细]
author-avatar
瑞景地产王琴
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有