题目
实现一个函数,检查一棵二叉树是否为二叉搜索树。
示例
输入:
2
/
1 3
输出: true
输入:
5
/
1 4
/
3 6
输出: false
解释: 输入为: [5,1,4,null,null,3,6]。
根节点的值为 5 ,但是其右子节点值为 4 。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/legal-binary-search-tree-lcci
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
方法1:递归
Java实现
class Solution {
public boolean isValidBST(TreeNode root) {
if (root == null) return true;
return isvalid(root, null, null);
}
public boolean isvalid(TreeNode root, TreeNode min, TreeNode max) {
if (root == null) return true;
if (min != null && root.val <= min.val) return false;
if (max != null && root.val >= max.val) return false;
return isvalid(root.left, min, root) && isvalid(root.right, root, max);
}
}