news 2026/6/23 18:20:02

LeetCode 热题 100——图论——实现 Trie (前缀树)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 热题 100——图论——实现 Trie (前缀树)

实现 Trie (前缀树)

题目描述

Trie(发音类似 “try”)或者说 前缀树 是一种树形数据结构,用于高效地存储和检索字符串数据集中的键。这一数据结构有相当多的应用情景,例如自动补全和拼写检查。

请你实现 Trie 类:

Trie() 初始化前缀树对象。
void insert(String word) 向前缀树中插入字符串 word 。
boolean search(String word) 如果字符串 word 在前缀树中,返回 true(即,在检索之前已经插入);否则,返回 false 。
boolean startsWith(String prefix) 如果之前已经插入的字符串 word 的前缀之一为 prefix ,返回 true ;否则,返回 false 。

示例:

输入
[“Trie”, “insert”, “search”, “search”, “startsWith”, “insert”, “search”]
[[], [“apple”], [“apple”], [“app”], [“app”], [“app”], [“app”]]
输出
[null, null, true, false, true, null, true]

解释
Trie trie = new Trie();
trie.insert(“apple”);
trie.search(“apple”); // 返回 True
trie.search(“app”); // 返回 False
trie.startsWith(“app”); // 返回 True
trie.insert(“app”);
trie.search(“app”); // 返回 True

提示:

1 <= word.length, prefix.length <= 2000
word 和 prefix 仅由小写英文字母组成
insert、search 和 startsWith 调用次数 总计 不超过 3 * 104 次

求解

varTrie=function(){this.root={children:{},// 子节点字典:{字符: 子节点}isEnd:false// 结束标识}};/** * @param {string} word * @return {void} */Trie.prototype.insert=function(word){letnode=this.root;for(letcharofword){if(!node.children[char]){node.children[char]={children:{},isEnd:false}}node=node.children[char];}node.isEnd=true;};/** * @param {string} word * @return {boolean} */Trie.prototype.search=function(word){letnode=this.root;for(letcharofword){if(!node.children[char]){returnfalse;}node=node.children[char];}if(node.isEnd)returntrue;returnfalse;};/** * @param {string} prefix * @return {boolean} */Trie.prototype.startsWith=function(prefix){letnode=this.root;for(letcharofprefix){if(!node.children[char]){returnfalse;}node=node.children[char];}returntrue;};/** * Your Trie object will be instantiated and called as such: * var obj = new Trie() * obj.insert(word) * var param_2 = obj.search(word) * var param_3 = obj.startsWith(prefix) */
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/14 22:32:25

揭秘Java:深度解析线程调度算法!

文章目录揭秘Java&#xff1a;深度解析线程调度算法&#xff01;一、什么是线程调度&#xff1f;二、Java线程调度的基本原理1. 时间片轮转&#xff08;Time-Slice Round-Robin&#xff09;2. 抢占式调度&#xff08;Preemptive Scheduling&#xff09;3. 分时调度&#xff08;…

作者头像 李华
网站建设 2026/6/23 18:18:43

三大电商API应用对比:淘宝京东拼多多谁能笑到最后?

一、API开放平台架构对比淘宝开放平台采用分层架构&#xff1a;API网关层$G$、业务逻辑层$B$、数据访问层$D$响应时间模型&#xff1a;$$T_{total} T_g T_b T_d \epsilon$$日均调用量&#xff1a;$QPS \geq 500$京东宙斯平台微服务架构&#xff1a;$n$个独立服务模块负载均…

作者头像 李华
网站建设 2026/6/23 8:48:20

2025年亲测7个降a率工具:AIGC率90%怎么降低ai?(附免费降AI1000字数)

市场上的降AI率工具良莠不齐&#xff0c;如何科学判断降AI率效果是很多学生、老师最关心的问题&#xff0c;担心降不来AI率&#xff0c;耽误时间还花不少钱。 本文将从以下五个维度系统&#xff0c;分析2025年主流的8个降AI工具&#xff0c;教大家如何选择适合自己的降AIGC工具…

作者头像 李华
网站建设 2026/6/22 21:51:49

ACL实验报告

一、实验拓扑二、实验需求1、全网互通&#xff1b;2、PC1可以Telnet R1&#xff0c;不能ping R13、PC1不能Telnet R2&#xff0c;但可以ping R24、PC2和PC1相反三、实验思路1、配置IP地址2、配置静态路由&#xff0c;实现全网通3、配置Telnet&#xff0c;并测试4、配置ACL&…

作者头像 李华
网站建设 2026/6/23 3:31:06

别再熬夜赶论文?6款AI工具帮你告别恐惧写作无压力!

还在对着空白文档发呆&#xff0c;从“致谢”开始写&#xff1f;还在为查重率50%焦虑到失眠&#xff0c;反复调换语序&#xff1f;还在因为导师一句“逻辑混乱&#xff0c;重写”而心态崩溃&#xff0c;觉得毕业遥遥无期&#xff1f; 如果你的答案是肯定的&#xff0c;那么你正…

作者头像 李华
网站建设 2026/6/23 9:44:21

一键导入书签,首页替代神器!批量去重、自动备份,维护不再头疼

「NAS、键盘、路由器年轻就要多折腾&#xff0c;我是爱折腾的熊猫—多面手博主&#xff01;咱主打的就是一个 “技能不压身&#xff0c;干货不掺水”」引言关于导航页熊猫写过不少了&#xff0c;已经写了如此多的情况下寻常的导航页已经入不了熊猫的眼了&#xff0c;但今天要介…

作者头像 李华