码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode-Inorder Successor in BST

时间:2016-09-04 14:24:29      阅读:124      评论:0      收藏:0      [点我收藏+]

标签:

Given a binary search tree and a node in it, find the in-order successor of that node in the BST.

Note: If the given node has no in-order successor in the tree, return null.

Solution:

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
    public class Result{
        TreeNode resNode;
        boolean foundP;
        boolean foundRes;
        public Result(){
            resNode = null;
            foundP = false;
            foundRes = false;
        }
    }
    public TreeNode inorderSuccessor(TreeNode root, TreeNode p) {
        Result res = new Result();
        searchTree(root,p,res);
        return res.resNode;
    }
    
    public void searchTree(TreeNode cur, TreeNode p, Result res){
        if (cur==null){
            return;
        }
        
        searchTree(cur.left,p,res);
        if (res.foundP && res.foundRes) return;
        if (res.foundP){
            res.resNode = cur;
            res.foundRes = true;
            return;
        }
        if (cur == p){
            res.foundP = true;
        }
        searchTree(cur.right,p,res);
    }
}

 

LeetCode-Inorder Successor in BST

标签:

原文地址:http://www.cnblogs.com/lishiblog/p/5839211.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!