-
Notifications
You must be signed in to change notification settings - Fork 0
/
1032.字符流.c
86 lines (71 loc) · 2.46 KB
/
1032.字符流.c
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/*
* @lc app=leetcode.cn id=1032 lang=c
*
* [1032] 字符流
*
* https://leetcode-cn.com/problems/stream-of-characters/description/
*
* algorithms
* Hard (35.07%)
* Likes: 33
* Dislikes: 0
* Total Accepted: 1.4K
* Total Submissions: 3.9K
* Testcase Example: '["StreamChecker","query","query","query","query","query","query","query","query","query","query","query","query"]\n' +
'[[["cd","f","kl"]],["a"],["b"],["c"],["d"],["e"],["f"],["g"],["h"],["i"],["j"],["k"],["l"]]'
*
* 按下述要求实现 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' 在字词表中。
*
*
*
* 提示:
*
*
* 1 <= words.length <= 2000
* 1 <= words[i].length <= 2000
* 字词只包含小写英文字母。
* 待查项只包含小写英文字母。
* 待查项最多 40000 个。
*
*
*/
// @lc code=start
typedef struct {
} StreamChecker;
StreamChecker* streamCheckerCreate(char ** words, int wordsSize) {
}
bool streamCheckerQuery(StreamChecker* obj, char letter) {
}
void streamCheckerFree(StreamChecker* obj) {
}
/**
* Your StreamChecker struct will be instantiated and called as such:
* StreamChecker* obj = streamCheckerCreate(words, wordsSize);
* bool param_1 = streamCheckerQuery(obj, letter);
* streamCheckerFree(obj);
*/
// @lc code=end