Skip to Content
Python Data Structures and Algorithms
book

Python Data Structures and Algorithms

by Benjamin Baka
May 2017
Intermediate to advanced
310 pages
8h 5m
English
Packt Publishing
Content preview from Python Data Structures and Algorithms

Searching the tree

Since the insert method organizes data in a specific way, we will follow the same procedure to find the data. In this implementation, we will simply return the data if it was found or None if the data wasn't found:

    def search(self, data): 

We need to start searching at the very top, that is, at the root node:

        current = self.root_node         while True: 

We may have passed a leaf node, in which case the data doesn't exist in the tree and we return None to the client code:

            if current is None:                 return None 

We might also have found the data, in which case we return it:

            elif current.data is data:                 return data 

As per the rules for how data is stored in the BST, if the data we are searching for is less than that of the current ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Start your free trial

You might also like

Data Structures and Algorithms in Python

Data Structures and Algorithms in Python

Michael T. Goodrich, Roberto Tamassia, Michael H. Goldwasser
Hands-On Data Structures and Algorithms with Python - Second Edition

Hands-On Data Structures and Algorithms with Python - Second Edition

Dr. Basant Agarwal, Benjamin Baka, David Julian
Data Structures & Algorithms in Python

Data Structures & Algorithms in Python

John Canning, Alan Broder, Robert Lafore

Publisher Resources

ISBN: 9781786467355Supplemental Content