- Learn more about data structures
- Work with a trie
Imagine you just rescued a dog and you’re deciding on a name. You found
a file online with a list of about 150 of the most popular dog names!
You are curious as to whether or not the names you are considering are
on this list. Since trie’s are great for data lookups, we’ve given you
some (almost!) complete code in trie.c
. There is one function,
check
, which is not yet implemented. Your job is to complete this
function.
- Log into cs50.dev using your GitHub account.
- Click inside the terminal window and execute
cd
. - Execute
wget https://cdn.cs50.net/2022/fall/labs/5/trie.zip
followed by Enter in order to download a zip calledtrie.zip
in your codespace. Take care not to overlook the space betweenwget
and the following URL, or any other character for that matter! - Now execute
unzip trie.zip
to create a folder calledtrie
. - You no longer need the ZIP file, so you can execute
rm trie.zip
and respond with “y” followed by Enter at the prompt.
Notice that the trie itself is implemented through the creative use of
several struct
s called node
. Each node
in a trie has an array of
(potential) children, with size 26—one potential child for each letter
of the alphabet! Adding words to this trie, notice that—for every letter
in a word—we create a new node
child whose parent is either the root
node (for the first letter) or the previous letter (if not the first
letter). On the very last letter, we set the is_word
attribute of the
child node
to true
. Now, checking if a word is in our trie is as
easy as following each letter of that word through our trie. If we get
to the final letter and see that is_word
is true, well, that name is
in our trie!
- Hints
- You probably want to start by setting a
node
pointer,cursor
to theroot
of the trie. - Iterate through every letter in the argument
word
and, as you do, determine the array index that corresponds to that letter. - You can use the index for a letter to check if
children[index]
is aNULL
pointer, meaning the word does not exist in the trie. - If
children[index]
is in fact a node, you can resetcursor
to this node and check for the next letter in itschildren
nodes. - Remember that the lookup should be case-insensitive. For instance,
A
anda
should correspond to 0,B
andb
corresponds to 1, etc.
- You probably want to start by setting a
- When might you want to use a trie as a data structure? When might you not?
Your program should behave per the examples below.
trie/ $ ./trie dog_names.txt
Check word: Molly
Found!
trie/ $ ./trie dog_names.txt
Check word: Lucy
Found!
trie/ $ ./trie dog_names.txt
Check word: Prudence
Not Found.
No check50
for this one!
To evaluate that the style of your code, type in the following at the
$
prompt.
style50 trie.c
No need to submit! This is a practice problem.