添加与搜索单词 - 数据结构设计

雪碧有白泡泡
优质创作者: 编程框架技术领域
2023-07-29 10:21:28

 

请你设计一个数据结构,支持 添加新单词 和 查找字符串是否与任何先前添加的字符串匹配 。

实现词典类 WordDictionary :

  • WordDictionary() 初始化词典对象
  • void addWord(word) 将 word 添加到数据结构中,之后可以对它进行匹配
  • bool search(word) 如果数据结构中存在字符串与 word 匹配,则返回 true ;否则,返回  false 。word 中可能包含一些 '.' ,每个 . 都可以表示任何一个字母。

 

示例:

输入:
["WordDictionary","addWord","addWord","addWord","search","search","search","search"]
[[],["bad"],["dad"],["mad"],["pad"],["bad"],[".ad"],["b.."]]
输出:
[null,null,null,null,false,true,true,true]

解释:
WordDictionary wordDictionary = new WordDictionary();
wordDictionary.addWord("bad");
wordDictionary.addWord("dad");
wordDictionary.addWord("mad");
wordDictionary.search("pad"); // 返回 False
wordDictionary.search("bad"); // 返回 True
wordDictionary.search(".ad"); // 返回 True
wordDictionary.search("b.."); // 返回 True

 

提示:

  • 1 <= word.length <= 25
  • addWord 中的 word 由小写英文字母组成
  • search 中的 word 由 '.' 或小写英文字母组成
  • 最多调用 104 次 addWord 和 search
...全文
174 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

8,574

社区成员

发帖
与我相关
我的任务
社区描述
个人主页:http://47.94.110.103:3000/
算法 个人社区 山西省·太原市
社区管理员
  • 雪碧有白泡泡
  • 程序边界
  • 直达CPU
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

欢迎各位加入刷踢日志社区,改社区会从基础内容进行更新,从0开始刷题,每块内容会分为不同频道方便区分学习交流

试试用AI创作助手写篇文章吧