Validate Binary Search Tree
Given a binary tree, determine if it is a valid binary search tree (BST).
Assume a BST is defined as follows:
The left subtree of a node contains only nodes with keys less than the node's key.
The right subtree of a node contains only nodes with keys greater than the node's key.
Both the left and right subtrees must also be binary search trees.
Example 1:
Example 2:
Solution
Value on right must be smaller than its parent value. And value on right must be higher than its parent value. So we can make an algorithm that will check whether a value of left node is in range from min value to max value (value of parent). At the same time, a value on right must be higher than root value and less than max value.
Here is a sample output of min and max values.
Last updated