热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[LeetCode]98.检验二叉搜索树的有效性

题目给定一个二叉树,判断其是否是一个有效的二叉搜索树。假设一个二叉搜索树具有如下特征:节点的左子树只包含小于当前节点的数。节点的右子树只包含大于当前节点的数。所有左子树和右子树自身

题目

给定一个二叉树,判断其是否是一个有效的二叉搜索树。

假设一个二叉搜索树具有如下特征:

节点的左子树只包含小于当前节点的数。

节点的右子树只包含大于当前节点的数。

所有左子树和右子树自身必须也是二叉搜索树。

来源:力扣(LeetCode)

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

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。


题解

由题,中序遍历是严格的递增,则是BST。

不需要将中序遍历结果存储,只需在中序遍历过程中比较序列临近两元素即可。


代码

public static boolean isValidBST(TreeNode root) {
Stack stack = new Stack<>();
TreeNode curNode = root;
long maxVal = Long.MIN_VALUE;
while (curNode != null || !stack.isEmpty()) {//
while (curNode != null) {
stack.push(curNode);
curNode = curNode.left;
}
curNode = stack.pop();
if (curNode.val > maxVal) {
maxVal = curNode.val;
curNode = curNode.right;//
} else {
return false;
}
}
return true;
}


推荐阅读
author-avatar
与人无缘-
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有