mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-26 02:00:27 +08:00
48 lines
2.9 KiB
HTML
48 lines
2.9 KiB
HTML
<p>Design an algorithm that accepts a stream of characters and checks if a suffix of these characters is a string of a given array of strings <code>words</code>.</p>
|
|
|
|
<p>For example, if <code>words = ["abc", "xyz"]</code> and the stream added the four characters (one by one) <code>'a'</code>, <code>'x'</code>, <code>'y'</code>, and <code>'z'</code>, your algorithm should detect that the suffix <code>"xyz"</code> of the characters <code>"axyz"</code> matches <code>"xyz"</code> from <code>words</code>.</p>
|
|
|
|
<p>Implement the <code>StreamChecker</code> class:</p>
|
|
|
|
<ul>
|
|
<li><code>StreamChecker(String[] words)</code> Initializes the object with the strings array <code>words</code>.</li>
|
|
<li><code>boolean query(char letter)</code> Accepts a new character from the stream and returns <code>true</code> if any non-empty suffix from the stream forms a word that is in <code>words</code>.</li>
|
|
</ul>
|
|
|
|
<p> </p>
|
|
<p><strong>Example 1:</strong></p>
|
|
|
|
<pre>
|
|
<strong>Input</strong>
|
|
["StreamChecker", "query", "query", "query", "query", "query", "query", "query", "query", "query", "query", "query", "query"]
|
|
[[["cd", "f", "kl"]], ["a"], ["b"], ["c"], ["d"], ["e"], ["f"], ["g"], ["h"], ["i"], ["j"], ["k"], ["l"]]
|
|
<strong>Output</strong>
|
|
[null, false, false, false, true, false, true, false, false, false, false, false, true]
|
|
|
|
<strong>Explanation</strong>
|
|
StreamChecker streamChecker = new StreamChecker(["cd", "f", "kl"]);
|
|
streamChecker.query("a"); // return False
|
|
streamChecker.query("b"); // return False
|
|
streamChecker.query("c"); // return False
|
|
streamChecker.query("d"); // return True, because 'cd' is in the wordlist
|
|
streamChecker.query("e"); // return False
|
|
streamChecker.query("f"); // return True, because 'f' is in the wordlist
|
|
streamChecker.query("g"); // return False
|
|
streamChecker.query("h"); // return False
|
|
streamChecker.query("i"); // return False
|
|
streamChecker.query("j"); // return False
|
|
streamChecker.query("k"); // return False
|
|
streamChecker.query("l"); // return True, because 'kl' is in the wordlist
|
|
</pre>
|
|
|
|
<p> </p>
|
|
<p><strong>Constraints:</strong></p>
|
|
|
|
<ul>
|
|
<li><code>1 <= words.length <= 2000</code></li>
|
|
<li><code>1 <= words[i].length <= 2000</code></li>
|
|
<li><code>words[i]</code> consists of lowercase English letters.</li>
|
|
<li><code>letter</code> is a lowercase English letter.</li>
|
|
<li>At most <code>4 * 10<sup>4</sup></code> calls will be made to query.</li>
|
|
</ul>
|