热门标签 | 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);}
};

推荐阅读
  • 利用决策树预测NBA比赛胜负的Python数据挖掘实践
    本文通过使用2013-14赛季NBA赛程与结果数据集以及2013年NBA排名数据,结合《Python数据挖掘入门与实践》一书中的方法,展示如何应用决策树算法进行比赛胜负预测。我们将详细讲解数据预处理、特征工程及模型评估等关键步骤。 ... [详细]
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本题涉及一棵由N个节点组成的树(共有N-1条边),初始时所有节点均为白色。题目要求处理两种操作:一是改变某个节点的颜色(从白变黑或从黑变白);二是查询从根节点到指定节点路径上的第一个黑色节点,若无则输出-1。 ... [详细]
  • 本题通过将每个矩形视为一个节点,根据其相对位置构建拓扑图,并利用深度优先搜索(DFS)或状态压缩动态规划(DP)求解最小涂色次数。本文详细解析了该问题的建模思路与算法实现。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 本文详细介绍了在企业级项目中如何优化 Webpack 配置,特别是在 React 移动端项目中的最佳实践。涵盖资源压缩、代码分割、构建范围缩小、缓存机制以及性能优化等多个方面。 ... [详细]
  • 本文详细介绍了如何解决OBS在全屏录制时出现黑屏的问题,并提供了关于正确配置显卡以实现高效推流的指导。通过调整操作系统和显卡设置,确保OBS能够稳定运行并提供高质量的直播或录制体验。 ... [详细]
  • 本文探讨了如何在iOS开发环境中,特别是在Xcode 6.1中,设置和应用自定义文本样式。我们将详细介绍实现方法,并提供一些实用的技巧。 ... [详细]
  • Python第三方库安装的多种途径及注意事项
    本文详细介绍了Python第三方库的几种常见安装方法,包括使用pip命令、集成开发环境(如Anaconda)以及手动文件安装,并提供了每种方法的具体操作步骤和适用场景。 ... [详细]
  • 深入理解Lucene搜索机制
    本文旨在帮助读者全面掌握Lucene搜索的编写步骤、核心API及其应用。通过详细解析Lucene的基本查询和查询解析器的使用方法,结合架构图和代码示例,带领读者深入了解Lucene搜索的工作流程。 ... [详细]
  • 本题探讨了在大数据结构背景下,如何通过整体二分和CDQ分治等高级算法优化处理复杂的时间序列问题。题目设定包括节点数量、查询次数和权重限制,并详细分析了解决方案中的关键步骤。 ... [详细]
  • 目录一、salt-job管理#job存放数据目录#缓存时间设置#Others二、returns模块配置job数据入库#配置returns返回值信息#mysql安全设置#创建模块相关 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 如何在PHPCMS V9中实现多站点功能并配置独立域名与动态URL
    本文介绍如何在PHPCMS V9中创建和管理多个站点,包括配置独立域名、设置动态URL,并确保各子站能够正常运行。我们将详细讲解从新建站点到最终配置路由的每一步骤。 ... [详细]
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社区 版权所有