211.添加与搜索单词-数据结构设计
请你设计一个数据结构,支持 添加新单词 和 查找字符串是否与任何先前添加的字符串匹配 。
实现词典类 WordDictionary :
- WordDictionary() 初始化词典对象
- void addWord(word) 将 word 添加到数据结构中,之后可以对它进行匹配
- bool search(word) 如果数据结构中存在字符串与 word 匹配,则返回 true ;否则,返回 false 。word 中可能包含一些 ‘.’ ,每个 . 都可以表示任何一个字母。
示例:
1 | 输入: |
提示:
- 1 <= word.length <= 500
- addWord 中的 word 由小写英文字母组成
- search 中的 word 由 ‘.’ 或小写英文字母组成
- 最多调用 50000 次 addWord 和 search
解题思路
整个字典是一个Map,map存储一个String的列表,以word的长度为key,当查找的时候,通过长度找出列表,列表中遍历查找对应的单词。
解题代码
1 | public class algorithm211 { |