news 2026/4/18 6:45:18

【算法专题训练】34、前缀树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【算法专题训练】34、前缀树

1、前缀树基础

前缀树又称为字典树,它用一个树状的数据结构存储一个字典中的所有单词,如图

  • 前缀树是一棵多叉树,一个节点可能有多个子节点,字典树的话子节点最多为26个(26个英文单词)。
  • 前缀树中除根节点外,每个节点表示字符串中的一个字符,而字符串由前缀树的路径表示。
  • 前缀树的根节点不表示任何字符

前缀树路径

  • 字符串在前缀树中的路径并不一定终止于叶节点。如果一个单词时另一个单词的前缀,那么较短的单词对应的路径是较长的单词对应的路径的一部分。
  • 如果前缀树路径到达某个节点时表示了一个完整的字符串,则字符串最后一个字符对应的结点有特殊的标识。

2、LCR 062. 实现 Trie (前缀树)

题目信息:

  • https://leetcode.cn/problems/QC3q1f/description/
Trie(发音类似"try")或者说 前缀树 是一种树形数据结构,用于高效地存储和检索字符串数据集中的键。这一数据结构有相当多的应用情景,例如自动补完和拼写检查。 请你实现 Trie 类:Trie()初始化前缀树对象。voidinsert(String word)向前缀树中插入字符串 word 。 booleansearch(String word)如果字符串 word 在前缀树中,返回true(即,在检索之前已经插入);否则,返回false。 booleanstartsWith(String prefix)如果之前已经插入的字符串 word 的前缀之一为 prefix ,返回true;否则,返回false。 示例: 输入 inputs=["Trie","insert","search","search","startsWith","insert","search"]inputs=[[],["apple"],["apple"],["app"],["app"],["app"],["app"]]输出[null,null,true,false,true,null,true]解释 Trie trie=newTrie();trie.insert("apple");trie.search("apple");// 返回 Truetrie.search("app");// 返回 Falsetrie.startsWith("app");// 返回 Truetrie.insert("app");trie.search("app");// 返回 True提示:1<=word.length,prefix.length<=2000word 和 prefix 仅由小写英文字母组成 insert、search 和 startsWith 调用次数 总计 不超过3*104

解题思路:

  • 1、审题:前缀树实现,前缀树是一颗多叉树,如果规定前缀树节点值保存的小写字母,则多叉树的子树大小为26(26个英文字母个数)
  • 2、解题:
  • 实现二叉树的字符串插入insert,字符串查询search,和前缀字符判断startsWith
  • 在构造函数中,定义一个26个大小的数组,用于标示当前结点的子节点保存位置
  • 当调用insert方法插入字符串时,先找到根节点,遍历字符串,并从前缀树的根节点开始判断,遍历到的字符在前缀树中是否存在,如果不存在则新建该字符标识的结点
    • 直到字符串全部遍历完,并将该结点标识为是单个单词
  • 查询方法search和前缀树内容判断,也是类似的思路

代码实现:

classTrie{public:Trie(){root=newTrieNode();}classTrieNode// 内部类{public:boolisWord=false;TrieNode*children[26];// 数组TrieNode(){for(inti=0;i<26;i++){children[i]=nullptr;}}~TrieNode(){for(inti=0;i<26;i++){deletechildren[i];children[i]=nullptr;}}};/** Inserts a word into the trie. */voidinsert(string word){TrieNode*node=root;for(inti=0;i<word.length();i++){intindex=word[i]-'a';if(node->children[index]==nullptr){node->children[index]=newTrieNode();}node=node->children[index];}node->isWord=true;}/** Returns if the word is in the trie. */boolsearch(string word){TrieNode*node=root;for(inti=0;i<word.length();i++){intindex=word[i]-'a';if(node->children[index]==nullptr){returnfalse;}node=node->children[index];}returnnode->isWord;}/** Returns if there is any word in the trie that starts with the given prefix. */boolstartsWith(string prefix){TrieNode*node=root;for(inti=0;i<prefix.length();i++){intindex=prefix[i]-'a';if(node->children[index]==nullptr){returnfalse;}node=node->children[index];}returntrue;}private:TrieNode*root;};

3、总结

  • 前缀树概念,字典树,是多叉树,每个单词对应树的一条路径,每个节点对应单词的结点
  • 单词结束位置的结点有特殊标记位 isWord
  • 前缀树的创建与查询,将单词插入到前缀树中,根据单词的字符查找对应位置的结点是否存在,不存在的话则新建结点,并重新赋值。
  • 单词查询方式也一样的逻辑,根据遍历到的字符位置查找结点,直到单词结尾的结点,并判断是否有结束标识。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 8:44:22

破解数据孤岛迷局,用F2B2b重构品牌渠道数字化增长的生态底座

站在2026年的商业风口&#xff0c;品牌商面临着前所未有的渠道大考。随着流量红利的消失和存量市场的内卷&#xff0c;传统的压货式分销模式已彻底失效。品牌商、经销商与终端门店之间的割裂&#xff0c;成为了制约增长的最大瓶颈。本文将深度剖析当前渠道数字化的核心痛点&…

作者头像 李华
网站建设 2026/4/18 5:21:25

为什么你的Shiny应用导出总失败?深度剖析多模态输出的7大坑点

第一章&#xff1a;Shiny应用多模态导出的核心挑战在构建交互式数据应用时&#xff0c;Shiny作为R语言生态中最流行的Web框架之一&#xff0c;广泛用于可视化展示与动态分析。然而&#xff0c;当用户需要将应用内容以多种格式&#xff08;如PDF、Word、Excel或图像&#xff09;…

作者头像 李华
网站建设 2026/4/18 4:50:58

10 个专科生论文写作工具,AI降重查重率推荐

10 个专科生论文写作工具&#xff0c;AI降重查重率推荐 论文写作的“三座大山”&#xff1a;时间、重复率与反复修改 对于专科生来说&#xff0c;论文写作从来不是一件轻松的事。从选题到文献综述&#xff0c;再到撰写正文和最终的降重修改&#xff0c;每一个环节都像一座难以逾…

作者头像 李华
网站建设 2026/4/17 8:29:20

Dify相关性评估技术深度解析(企业级搜索优化必备)

第一章&#xff1a;Dify相关性评估的核心概念与应用场景 Dify 是一个开源的大型语言模型应用开发平台&#xff0c;支持从模型编排、工作流设计到前端界面生成的全流程构建。在 Dify 系统中&#xff0c;相关性评估是衡量用户输入&#xff08;如问题或指令&#xff09;与系统响应…

作者头像 李华
网站建设 2026/4/18 7:04:00

音频质量检测进入AI时代,Dify 1.7.0如何重新定义行业标准?

第一章&#xff1a;音频质量检测进入AI时代传统音频质量检测依赖人工听测与基于信号的客观指标&#xff08;如信噪比、总谐波失真&#xff09;&#xff0c;不仅效率低下&#xff0c;且难以捕捉人耳感知层面的细微差异。随着深度学习技术的发展&#xff0c;AI正逐步接管这一任务…

作者头像 李华