Skip to content

Commit 50f2b9d

Browse files
committed
validate binary search tree solution
1 parent cedd6d9 commit 50f2b9d

File tree

1 file changed

+31
-0
lines changed

1 file changed

+31
-0
lines changed
Lines changed: 31 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,31 @@
1+
/**
2+
* Definition for a binary tree node.
3+
* public class TreeNode {
4+
* int val;
5+
* TreeNode left;
6+
* TreeNode right;
7+
* TreeNode() {}
8+
* TreeNode(int val) { this.val = val; }
9+
* TreeNode(int val, TreeNode left, TreeNode right) {
10+
* this.val = val;
11+
* this.left = left;
12+
* this.right = right;
13+
* }
14+
* }
15+
*/
16+
class Solution {
17+
public boolean isValidBST(TreeNode root) {
18+
return isValid(root, null, null);
19+
}
20+
21+
private boolean isValid(TreeNode node, Integer min, Integer max) {
22+
if (node == null) {
23+
return true;
24+
}
25+
26+
if (min != null && node.val <= min) return false;
27+
if (max != null && node.val >= max) return false;
28+
29+
return isValid(node.left, min, node.val) && isValid(node.right, node.val, max);
30+
}
31+
}

0 commit comments

Comments
 (0)