98.验证二叉搜索树
给定一个二叉树,判断其是否是一个有效的二叉搜索树。
假设一个二叉搜索树具有如下特征:
节点的左子树只包含小于当前节点的数。
节点的右子树只包含大于当前节点的数。
所有左子树和右子树自身必须也是二叉搜索树。
示例 1:
输入:
2
/ \
1 3
输出: true
示例 2:
输入:
5
/ \
1 4
/ \
3 6
输出: false
解释: 输入为: [5,1,4,null,null,3,6]。
根节点的值为 5 ,但是其右子节点值为 4 。
题解1:中序遍历
中序遍历时,判断当前节点是否大于中序遍历的前一个节点,如果大于,说明满足 BST,继续遍历;否则直接返回 false。
import javax.swing.tree.TreeNode;
/*
* @lc app=leetcode.cn id=98 lang=java
*
* [98] 验证二叉搜索树
*/
// @lc code=start
/**
* Definition for a binary tree node. public class TreeNode { int val; TreeNode
* left; TreeNode right; TreeNode() {} TreeNode(int val) { this.val = val; }
* TreeNode(int val, TreeNode left, TreeNode right) { this.val = val; this.left
* = left; this.right = right; } }
*/
class Solution {
long pre = Long.MIN_VALUE;
public boolean isValidBST(TreeNode root) {
// 中序遍历
// 时间复杂度:O(n)
// 空间复杂度:O(n)
if (root == null) {
return true;
}
// 访问左子树
if (!isValidBST(root.left)) {
return false;
}
// 访问当前节点:如果当前节点小于等于中序遍历的前一个节点,
// 说明不满足BST,返回 false;否则继续遍历。
if (root.val <= pre) {
return false;
}
pre = root.val;
// 访问右子树
return isValidBST(root.right);
}
}
题解2:递归,利用二叉搜索树定义
import javax.swing.tree.TreeNode;
/*
* @lc app=leetcode.cn id=98 lang=java
*
* [98] 验证二叉搜索树
*/
// @lc code=start
/**
* Definition for a binary tree node. public class TreeNode { int val; TreeNode
* left; TreeNode right; TreeNode() {} TreeNode(int val) { this.val = val; }
* TreeNode(int val, TreeNode left, TreeNode right) { this.val = val; this.left
* = left; this.right = right; } }
*/
class Solution {
public boolean isValidBST(TreeNode root) {
// 递归,利用二叉搜索树定义
// 时间复杂度:O(n)
// 空间复杂度:O(n)
return isValidBST(root, Long.MIN_VALUE, Long.MAX_VALUE);
}
private boolean isValidBST(TreeNode root, long lower, long upper) {
if (root == null) {
return true;
}
// 如果当前节点的值超过上界或低于下界,则返回flase
if (root.val <= lower || root.val >= upper) {
return false;
}
// 左右子树是否均符合二叉搜索树定义
return isValidBST(root.left, lower, root.val) && isValidBST(root.right, root.val, upper);
}
}