今天是2020年5月5日,星期二,时隔好几天没有在写每日一题,因为五一期间自己也有一些事情,最近还生病打点滴。
题目描述
给定一个二叉树,判断其是否是一个有效的二叉搜索树。
假设一个二叉搜索树具有如下特征:
- 节点的左子树只包含小于当前节点的数。
- 节点的右子树只包含大于当前节点的数。
- 所有左子树和右子树自身必须也是二叉搜索树。
示例 1:
输入:
2
/ \
1 3
输出: true
示例 2:
输入:
5
/ \
1 4
/ \
3 6
输出: false
解释: 输入为: [5,1,4,null,null,3,6]。
根节点的值为 5 ,但是其右子节点值为 4 。
题目分析
在开始看本题目的时候,认为只需要判定当前节点值比其左右节点值大即可。在实现时使用了二叉树的层次遍历即可能会误判,即右子树中存在比根节点小的值,这个值本来应该在左子树中某一个节点的右子树上。下图所示的情况就会出现误判操作。
可以使用二叉树的中序遍历,左中右的遍历顺序,可以保证先到达子树的根节点后,由下向上比较,这时只要保证左子树值<根节点值,右子树的值>根节点,那么绝对不会存在误判情况。判断过程如下所示。
参考代码
class Solution {
private long pre = Long.MIN_VALUE;
/**
* 中序遍历
*
* @param root
* @return
*/
public boolean isValidBST(TreeNode root) {
if (root == null) {
return true;
}
// 访问左子树
if (!isValidBST(root.left)) {
return false;
}
// 如果当前节点的值小于之前中序遍历的值,则说明不满足BST,返回false;
if (root.val <= pre) {
return false;
}
pre = root.val;
if (!isValidBST(root.right)) {
return false;
}
return true;
}
}