zoukankan      html  css  js  c++  java
  • Leetcode 98 验证二叉搜索树

    题目定义:

    给定一个二叉树,判断其是否是一个有效的二叉搜索树。
    
    假设一个二叉搜索树具有如下特征:
    
    节点的左子树只包含小于当前节点的数。
    节点的右子树只包含大于当前节点的数。
    所有左子树和右子树自身必须也是二叉搜索树。
    示例 1:
    
    输入:
        2
       / 
      1   3
    输出: true
    示例 2:
    
    输入:
        5
       / 
      1   4
         / 
        3   6
    输出: false
    解释: 输入为: [5,1,4,null,null,3,6]。
         根节点的值为 5 ,但是其右子节点值为 4 。
    
    

    方式一(递归判断):

    class Solution {
        public boolean isValidBST(TreeNode root) {
            if(root == null)
                return true;
            return recursion(root,null,null);
        }
        private boolean recursion(TreeNode root,Integer lower,Integer upper){
            if(root == null)   
                return true;
            if((lower != null && root.val <= lower) || (upper != null && root.val >= upper))
                 return false;
            return recursion(root.left,lower,root.val) 
                && recursion(root.right,root.val,upper);
        }
    
    }
    

    方式二(中序遍历):

    class Solution {
        public boolean isValidBST(TreeNode root) {
            if(root == null)
                return true;
            Deque<TreeNode> stack = new ArrayDeque<>();
            double prev = - Double.MAX_VALUE;
            while(!stack.isEmpty() || root != null){
               while(root != null){
                   stack.push(root);
                   root = root.left;
               }
               root = stack.pop();
               if(root.val <= prev)
                 return false;
               prev = root.val; 
               root = root.right;
            }
            return true;
        }
      
    

    方式三(morris遍历):

    class Solution {
        public boolean isValidBST(TreeNode root) {
            Integer idx = null;
            while(root != null){
                if(root.left == null){
                    int cur = root.val;
                    if(idx == null){
                        idx = cur;
                    }else if(idx >= cur){
                        return false;
                    }
                    idx = cur;
                    root = root.right;
                }else{
                    TreeNode pre = root.left;
                    while(pre.right != null && pre.right != root){
                        pre = pre.right;
                    }
                    if(pre.right == null){
                        pre.right = root;
                        root = root.left;
                    }else{
                        pre.right = null;
                        //下方判断与if(root.left == null)的判断相同,可提取出公共方法
                        int cur = root.val;
                        if(idx == null){
                            idx = cur;
                        }else if(idx >= cur){
                            return false;
                        }
                        idx = cur;
                        root = root.right;
                    }
                }
            }
            return true;
        }
        
    }
    

    参考:

    https://leetcode-cn.com/problems/validate-binary-search-tree/

  • 相关阅读:
    HDU 5441 离线处理 + 并查集
    [转载]HDU 3478 判断奇环
    POJ 1637 混合图的欧拉回路判定
    [转载] 一些图论、网络流入门题总结、汇总
    UVA 820 --- POJ 1273 最大流
    [转载 ]POJ 1273 最大流模板
    POJ 3041 -- 二分图匹配
    2014西安现场赛F题 UVALA 7040
    UVA 12549
    割点、桥(一点点更新)
  • 原文地址:https://www.cnblogs.com/CodingXu-jie/p/14240637.html
Copyright © 2011-2022 走看看