news 2026/4/24 6:09:23

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/4/23 11:13:13

【JavaWeb】乱码问题_POST请求参数乱码问题

目录POST请求参数乱码问题POST请求参数乱码问题 请求表单代码如下 servlet代码 提交 此时会乱码&#xff0c;编码用的GBK&#xff0c;但是tomcat10 默认是以UTF-8为请求体的解码字符集 此时不能通过修改tomcat安装目录下的conf/server.xml文件解决 即在下面添加URIEncoding不…

作者头像 李华
网站建设 2026/4/23 1:07:51

淘宝、京东、拼多多API大比拼,谁才是电商运营的最佳拍档?

在电商运营的数字化浪潮中&#xff0c;高效、稳定的API接口已成为商家和开发者提升效率、优化流程的关键工具。淘宝、京东、拼多多作为国内三大电商巨头&#xff0c;其开放平台提供的API能力各有千秋。本文将从接口丰富度、调用效率、文档质量、生态支持等多个维度进行深度对比…

作者头像 李华
网站建设 2026/4/23 11:14:18

学长墙裂推荐的7个降AI工具,果然去AI痕迹都很厉害!

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

作者头像 李华
网站建设 2026/4/23 11:13:14

还在熬夜赶问卷论文?8款AI工具1天生成万字+高信度数据!

别再…还在…难道你还没发现&#xff1f; 别再凌晨三点对着空白Word发呆了&#xff1f; 还在用手动拼凑问卷、跑SPSS、改参考文献到眼酸&#xff1f; 难道你还没意识到——用老办法写论文&#xff0c;不仅拖垮身体&#xff0c;还可能被导师批到怀疑人生&#xff1f; 如果你的…

作者头像 李华
网站建设 2026/4/23 12:19:24

还在为毕业论文熬夜?9款AI神器助力知网查重一把过,不留AIGC痕迹!

别再…还在用笨办法死磕论文&#xff1f;别再拿健康换进度&#xff1f;别再因为查重和AI率被导师打回重写&#xff1f; 如果你此刻正对着空白Word发呆到凌晨两点&#xff1b;如果你为了把查重率从40%压到10%反复删改到崩溃&#xff1b;如果你的导师在批注里写下“结构混乱、AI…

作者头像 李华
网站建设 2026/4/23 12:52:33

大型语言模型革命:从传统编程到学习型智能,彻底改变世界的力量与挑战!

简介 文章介绍了大型语言模型(LLM)从传统指令编程到学习型智能的范式革命&#xff0c;涵盖LLM的基本概念、发展历程、工作原理、训练方法及未来应用方向。LLM通过学习数据中的模式而非执行固定规则来完成任务&#xff0c;这一转变正在重塑编程、写作、客服等多个行业。同时探讨…

作者头像 李华