 
 Data Structure Data Structure
 Networking Networking
 RDBMS RDBMS
 Operating System Operating System
 Java Java
 MS Excel MS Excel
 iOS iOS
 HTML HTML
 CSS CSS
 Android Android
 Python Python
 C Programming C Programming
 C++ C++
 C# C#
 MongoDB MongoDB
 MySQL MySQL
 Javascript Javascript
 PHP PHP
- Selected Reading
- UPSC IAS Exams Notes
- Developer's Best Practices
- Questions and Answers
- Effective Resume Writing
- HR Interview Questions
- Computer Glossary
- Who is Who
Validate Binary Search Tree in Python
A binary search tree is a special binary tree in which for every node, the left subtree contains values less than the node's value, and the right subtree contains values greater than the node's value.
In this article, we will discuss how to validate whether a given binary tree is a valid binary search tree (BST) in Python.
- Validate Binary Search Tree
- Algorithm to Validate Binary Search Tree
- Python Program to Validate Binary Search Tree
Validate Binary Search Tree
Given a root node of a binary tree, we need to determine if it is a valid binary search tree (BST). A BST is valid if:
- 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.
Scenario 1
Input:
Root node: 10
        10
       /  \
      5    15
     / \     \
    3   7    20
Output:
True
In this scenario, the given binary tree is a valid binary search tree (BST) because it satisfies all the properties of a BST.
Scenario 2
Input:
Root node: 11
        11
       /  \
      6     3
     / \     \
    10   7    20
Output:
False
In this scenario, the given binary tree is not a valid binary search tree (BST) because the right child of the root node (3) is less than the root node (11) itself, violating the BST property.
Algorithm to Validate Binary Search Tree
To validate a binary search tree, we can use a recursive approach. The idea is to keep track of the valid range for each node's value as we traverse the tree. Here are the steps:
- Start with the root node and set the initial valid range as (-infinity, +infinity).
- For each node, check if its value falls within the valid range.
- If the value is valid, recursively check the left subtree with an updated range (-infinity, node.value) and the right subtree with an updated range (node.value, +infinity).
- If any node violates the BST property, return false.
- Return true if all nodes satisfy the BST property.
Python Program to Validate Binary Search Tree
Here is a Python program that implements the above algorithm to validate a binary search tree:
class TreeNode:
    def __init__(self, value):
        self.value = value
        self.left = None
        self.right = None
def is_valid_bst(root, min_val=float('-inf'), max_val=float('inf')):
    if root is None:
        return True
    if not (min_val < root.value < max_val):
        return False
    return (is_valid_bst(root.left, min_val, root.value) and
            is_valid_bst(root.right, root.value, max_val))
# Create a sample binary search tree (as in scenario 1)
root = TreeNode(10)
root.left = TreeNode(5)
root.right = TreeNode(15)
root.left.left = TreeNode(3)
root.left.right = TreeNode(7)
root.right.right = TreeNode(20)
# Validate the binary search tree
print(is_valid_bst(root)) 
The output of the program will be:
True
