LeetCode 重构二叉搜索数,即找出两个被交换的节点
来源:互联网 发布:linux中文显示方框 编辑:程序博客网 时间:2024/05/21 09:12
原题:Two elements of a binary search tree (BST) are swapped by mistake.
Recover the tree without changing its structure.
Note:A solution using O(n) space is pretty straight forward. Could you devise a constant space solution?
confused what"{1,#,2,3}"means? > read more on how binary tree is serialized on OJ.
OJ's Binary Tree Serialization:
The serialization of a binary tree follows a level order traversal, where '#' signifies a path terminator where no node exists below.
Here's an example:
1 / \ 2 3 / 4 \ 5The above binary tree is serialized as"{1,2,3,#,#,4,#,#,5}".
题意:二叉搜索树中,有两个结点的位置被交换了,请找出这两个结点并交换回来。
“直观的想法可能是中序遍历一遍二叉树,得到一个有序的二叉树,然后找出其中逆序的地方,交换回来就好了。但这样空间复杂度就是O(n),题目要求O(1)。
我们来分析下有哪些情况:1) 被交换的两个结点相邻,如124356,这样只需要把相邻的3和4交换回来即可;2) 被交换的两个结点不相邻,如163452,这样我们需要找出两个逆序的地方,63和52,并交换第一个逆序的前者和第二个逆序的后者。”(http://blog.csdn.net/ljiabin/article/details/44514651该博主很认真解释了一下,不然光看程序还真看不懂)。因为这两种情况存在,而且这可二叉树只有两个节点被交换了,所以我们需要定位这两个节点,而不是将相邻节点一对一对的交换达到这种效果。这一点也是最精妙的地方,程序中mistake1记录的最底下出错的节点,mistake2记录的是中序遍历中较mistake1后面的节点。
/**
* Definition for binary tree*/
int val;
TreeNode left;
TreeNode right;
TreeNode(int x) { val = x;
}
}
class Solution {
private TreeNode pre=null;
private TreeNode mistake1,mistake2=null;
public void recoverTree(TreeNode root) {
inOrderTraversal(root);
int temp=mistake2.val;
mistake2.val=mistake1.val;
mistake1.val=temp;
}
/*中序遍历查找出错的两个节点,只有两个节点出错哦
* 左节点值<根节点值<右节点值
* 首先从左子树遍历到底
* */
public void inOrderTraversal(TreeNode root){
if(root==null)
return;
//中序遍历
inOrderTraversal(root.left);//左子树遍历到底
if(pre!=null&&pre.val>root.val){
if(mistake1==null)
mistake1=pre;
mistake2=root;
}
pre=root;//最底下的左节点
inOrderTraversal(root.right);
}
- LeetCode 重构二叉搜索数,即找出两个被交换的节点
- 每天一道LeetCode-----二叉搜索树的某两个节点被交换位置,修正这个二叉搜索树
- 恢复被交换二叉搜索树的节点值
- 找出二叉搜索树的最大节点和最小节点
- 找出二叉树中某两个节点的第一个公共祖先
- 找出二叉搜索树中出现最频繁的节点
- 找出二叉搜索树第k大的节点
- 交换二叉树中每个节点的两个子女
- leetcode交换相邻的两个节点的值
- C++中交换两个数/二叉树的建立
- [LeetCode] 一个BST的两个节点的值被交换,要求修正这个BST
- 两个数的交换
- 两个数的交换
- 两个数的交换
- 两个数的交换
- 找出二叉树上任意两个节点的最近共同父节点
- 找出二叉树中任意两个节点的最低公共父节点
- 调整搜索二叉树中两个错误的节点
- loadrunner问题记录
- 使用maven创建web项目
- linux 下mysql的备份和恢复
- Visual Studio 2015专业版创建Win32控制台应用程序,C,C++源文件
- 位掩码(bitmask)在windows 串口事件驱动中的应用
- LeetCode 重构二叉搜索数,即找出两个被交换的节点
- HDU1026:Ignatius and the Princess I(BFS)
- 有史以来最悲剧审核被拒的经历-关于iCloud到底应该备份什么数据
- Maven详解之仓库------本地仓库、远程仓库
- webview温习
- 线程的生命周期
- 深度优先搜索算法
- Linux下修改Mysql密码的三种方式
- ARGB内存占用