LeetCode-98-验证二叉搜索树

1题目

给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。

有效 二叉搜索树定义如下:

  • 节点的左子树只包含 小于 当前节点的数。
  • 节点的右子树只包含 大于 当前节点的数。
  • 所有左子树和右子树自身必须也是二叉搜索树。

示例 1:

img
1
2
输入:root = [2,1,3]
输出:true

示例 2:

img
1
2
3
输入:root = [5,1,4,null,null,3,6]
输出:false
解释:根节点的值是 5 ,但是右子节点的值是 4

提示:

  • 树中节点数目范围在[1, 104]
  • -231 <= Node.val <= 231 - 1

题解

我的思路是先建立中序遍历序列,然后对该序列进行判断,如果不是递增序列,就返回false即可。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
class Solution {
public boolean isValidBST(TreeNode root) {
// 中序遍历序列进行判断,左子树小于,右子树大于
List<Integer> list = new ArrayList<>();
dfs(root, list);
for (int i = 0; i < list.size() - 1; i++) {
if (list.get(i + 1) <= list.get(i)) {
return false;
}
}
return true;
}

public void dfs(TreeNode root, List<Integer> list) {
if (root == null) {
return;
}
dfs(root.left, list);
list.add(root.val);
dfs(root.right, list);
}
}

LeetCode-98-验证二叉搜索树
https://excelius.xyz/leetcode-98-验证二叉搜索树/
作者
Excelius
发布于
2024年7月31日
许可协议