Relevant articles: The Trie Data Structure in Java Implementing a Binary Tree in Java Depth First Search in Java