Solution: Stream of Characters
Explore how to design a data structure that processes a stream of characters to identify suffix matches from a given list. Learn to reverse words for suffix matching, build a Trie for efficient lookups, and use a deque to manage dynamic character streams. Understand the solution's time and space complexities and apply these techniques to solve similar string matching problems efficiently.
We'll cover the following...
Statement
Design a data structure that processes a stream of characters and, after each character is received, determines if a suffix of these characters is a string in a given array of strings words.
For example, if words = ["cat"] and the stream adds the characters
So, for words, the goal is to detect if any of these words appear as a suffix of the stream built so far. To accomplish this, implement a class StreamChecker:
Constructor: Initializes the object with the list of target
words.boolean query(char letter): Appends a character to the stream and returns TRUE if any suffix of the stream matches a word in the list
words.
Constraints:
words.length...