首页 > 其他 > 详细

【LeetCode】Recover Binary Search Tree

时间:2014-05-21 19:10:56      阅读:409      评论:0      收藏:0      [点我收藏+]

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?

bubuko.com,布布扣
public class Solution {
    public void recoverTree(TreeNode root) {
        if(root!=null){
            Stack<TreeNode> stack = new Stack<TreeNode>();
            TreeNode cur = root;
            int min=Integer.MIN_VALUE;
            int preint = Integer.MIN_VALUE;
            TreeNode pre=root;
            TreeNode after=pre;
            boolean bol = true;
            while(!stack.isEmpty()||cur!=null){
                while(cur!=null){
                    stack.push(cur);
                    cur=cur.left;
                }
                if(!stack.isEmpty()){
                    int temp = stack.peek().val;
                    if(bol&&temp>preint){
                        preint = temp;
                        pre=stack.peek();
                    }
                    if(bol&&temp<preint){
                        bol=false;
                        min=temp;
                        after=stack.peek();
                        cur=stack.peek().right;
                        stack.pop();
                        continue;
                    }
                    if(!bol&&temp<min){
                        min=temp;
                        after=stack.peek();
                    }
                    cur=stack.peek().right;
                    stack.pop();
                    
                }
            }
            int tt  = pre.val;
            pre.val=after.val;
            after.val=tt;
        }
    }
}
bubuko.com,布布扣

 

【LeetCode】Recover Binary Search Tree,布布扣,bubuko.com

【LeetCode】Recover Binary Search Tree

原文:http://www.cnblogs.com/yixianyixian/p/3740197.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!