Implementing a Trie
Learn to implement a trie with the help of pseudocode and working code in C++ and Java.
Tries
A trie data structure is utilized for searching or retrieving data. The most critical and frequent operations involved in a trie data structure are:
Insertion of a word.
Searching for a word/prefix.
Implementing tries
Let's begin implementing a trie class with given functions.
Trie()
: This initializes the trie object.void insert (String word)
: This inserts the string word into the trie.boolean search (String word)
: This returnstrue
if the string word exists in the trie (i.e., it was inserted earlier) andfalse
otherwise.boolean startsWith (String pref)
: This returnstrue
if a previously inserted string word contains pref as a prefix; it returnsfalse
otherwise.
Trie node
Every node of the trie can have multiple children. Each child represents a possible character of the key/string. A popular way is to mark the last node of every key/string as the end of the word node.
A trie node field isEndOfWord
distinguishes the node as the end of the word node. A simple structure to represent nodes of the English alphabet is as follows.
Get hands-on with 1300+ tech skills courses.