news 2026/4/16 15:25:32

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/15 15:15:56

拼多多API赋能,新农人也能玩转电商大舞台!

在数字化农业浪潮中&#xff0c;拼多多开放平台API正成为新农人撬动电商市场的技术杠杆。本文将深入解析如何通过API实现农产品上架、订单管理、营销活动等核心功能&#xff0c;并附完整代码示例。一、API接入基础开发者注册访问拼多多开放平台&#xff0c;完成企业资质认证&am…

作者头像 李华
网站建设 2026/4/16 9:02:36

2025最新汇总7款降ai率工具,轻松通过AIGC检测!

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

作者头像 李华
网站建设 2026/4/15 15:12:08

还在为论文重复率高发愁?8款AI改重降重工具,一键替换高级表达!

还在手动逐字逐句“调换语序”、“替换近义词”来降重&#xff1f;还在为改到面目全非却依然标红而彻夜难眠&#xff1f;还在担心AI生成的论文“一眼假”&#xff0c;过不了AIGC检测&#xff0c;导致学术不端的风险&#xff1f; 如果你的答案是肯定的&#xff0c;那么请立刻停…

作者头像 李华
网站建设 2026/4/16 10:42:34

Delphi凭什么挑战Excel VBA?背后深意很多人没看懂

说 Delphi 死了的人&#xff0c;大多没真正用过它。而说 Excel VBA 万能的人&#xff0c;基本都还没被业务折磨够。就在我上一篇写 Python 和 VBA 的文章下面&#xff0c;有读者突然冒出一句话&#xff1a;delphi7 才是Excel编程神器。相信这句话戳中了不少老程序员用过delphi的…

作者头像 李华
网站建设 2026/4/10 6:18:06

SimulCrypt 与 BISS:线性电视中的内容保护机制

在线性广播中&#xff0c;内容保护是任何 DVB 或 IPTV 网络的基础组成部分。广播商——包括卫星、有线和 IPTV 运营商——在内容制作和采购上投入巨大。借助加密技术&#xff0c;他们能够通过销售订阅服务、控制访问权限来实现内容变现&#xff0c;并防止未经授权的复制或再分发…

作者头像 李华