Leetcode 字符流

WechatIMG553.jpeg

题目描述

leetcode 第1032题:字符流
按下述要求实现 StreamChecker 类:
StreamChecker(words):构造函数,用给定的字词初始化数据结构。
query(letter):如果存在某些 k >= 1,可以用查询的最后 k个字符(按从旧到新顺序,包括刚刚查询的字母)拼写出给定字词表中的某一字词时,返回 true。否则,返回 false。
示例:
StreamChecker streamChecker = new StreamChecker([“cd”,”f”,”kl”]); // 初始化字典
streamChecker.query(‘a’); // 返回 false
streamChecker.query(‘b’); // 返回 false
streamChecker.query(‘c’); // 返回 false
streamChecker.query(‘d’); // 返回 true,因为 ‘cd’ 在字词表中
streamChecker.query(‘e’); // 返回 false
streamChecker.query(‘f’); // 返回 true,因为 ‘f’ 在字词表中
streamChecker.query(‘g’); // 返回 false
streamChecker.query(‘h’); // 返回 false
streamChecker.query(‘i’); // 返回 false
streamChecker.query(‘j’); // 返回 false
streamChecker.query(‘k’); // 返回 false
streamChecker.query(‘l’); // 返回 true,因为 ‘kl’ 在字词表中。

解题方法

字典树
部分代码语言可能存在超时
参照题解

  • 解题思路

构建字典树root,创建双向队列stream
遍历数组words,将每个单词word反转后存入root
每次query时,向stream的左侧插入letter
遍历stream,在root中查询每次输入的letter是否存在

  • 复杂度

时间复杂度:O(n)
空间复杂度:O(n)

  • 代码实现

python3

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
class Trie:
def __init__(self):
self.next = {}
self.isWrod = False

class StreamChecker:
def __init__(self, words: List[str]):
self.root = Trie()
self.stream = deque([])
for word in words:
self.addWord(word)

def addWord(self, word):
tree = self.root
for c in word[::-1]:
if c not in tree.next:
tree.next[c] = Trie()
tree = tree.next[c]
if not tree.isWrod:
tree.isWrod = True

def query(self, letter: str) -> bool:
self.stream.appendleft(letter)
tree = self.root
for c in self.stream:
if c not in tree.next:
return False
tree = tree.next[c]
if tree.isWrod:
return True
return False

php

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
class Trie {
public $next = [];
public $isWord = false;
}
class StreamChecker {
function __construct($words) {
$this->root = new Trie();
$this->stream = [];
array_map([$this,'addWord'],$words);
}

function addWord($word){
$word = strrev($word);
$tree = $this->root;
for($i=0;$i<strlen($word);$i++){
$c = $word[$i];
if(!isset($tree->next[$c])){
$tree->next[$c] = new Trie();
}
$tree = $tree->next[$c];
}
if(!$tree->isWord){
$tree->isWord = true;
}
}

function query($letter) {
array_unshift($this->stream,$letter);
print_r($this->stream);
$tree = $this->root;
foreach($this->stream as $c){
if(!isset($tree->next[$c])){
return false;
}
$tree = $tree->next[$c];
if($tree->isWord){
return true;
}
}
return false;
}
}
-------------本文结束感谢您的阅读-------------
0%