Validate BST
class BST {
constructor(value) {
this.value = value;
this.left = null;
this.right = null;
}
}
// O(n) time | O(d) space
function validateBst(tree) {
return validateBstHelper(tree, -Infinity, Infinity);
}
function validateBstHelper(tree, minValue, maxValue) {
if (tree === null) return true;
if (tree.value < minValue || tree.value >= maxValue) return false;
const leftIsValid = validateBstHelper(tree.left, minValue, tree.value);
return leftIsValid && validateBstHelper(tree.right, tree.value, maxValue);
}
exports.BST = BST;
exports.validateBst = validateBst;
Last updated