news 2026/2/22 3:14:20

【算法专题训练】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/2/20 19:32:41

为什么你的AI系统日志总是不同步?,Dify+Spring AI最佳实践曝光

第一章&#xff1a;为什么你的AI系统日志总是不同步&#xff1f;在分布式AI系统中&#xff0c;日志不同步是一个常见但容易被忽视的问题。多个计算节点、异步推理任务以及不一致的时间戳来源&#xff0c;往往导致日志记录出现时间漂移或顺序错乱&#xff0c;进而影响故障排查和…

作者头像 李华
网站建设 2026/2/22 9:47:09

仿真、运维与超现实可视化的融合—— “易控天地”亮相中国系统仿真与虚拟现实技术高层论坛

“仿真”和“运维”在建设复杂系统中是两个重要的阶段。“仿真”是在数字空间中模拟现实系统&#xff0c;验证设计的正确性&#xff0c;“运维”则是在现实世界中应对系统真实工况&#xff0c;处理那些在“设计”时未曾预料&#xff0c;“仿真”时未能模拟的复杂问题。仿真和运…

作者头像 李华
网站建设 2026/2/17 12:49:00

【气候驱动农业决策】:R语言在产量预测中的高级应用技巧

第一章&#xff1a;农业产量的 R 语言气候影响分析在现代农业研究中&#xff0c;理解气候变量对农作物产量的影响至关重要。R 语言凭借其强大的统计分析与可视化能力&#xff0c;成为处理农业与气象数据的理想工具。通过整合历史气象记录&#xff08;如温度、降水、日照时数&am…

作者头像 李华
网站建设 2026/2/14 16:23:10

8个AI论文工具,继续教育学员轻松搞定毕业写作!

8个AI论文工具&#xff0c;继续教育学员轻松搞定毕业写作&#xff01; AI 工具如何助力论文写作&#xff0c;让毕业不再焦虑 在继续教育的学习过程中&#xff0c;论文写作往往成为学员们最头疼的环节。无论是开题报告、大纲构建&#xff0c;还是初稿撰写和降重处理&#xff0c;…

作者头像 李华
网站建设 2026/2/17 13:30:56

8 个自考答辩PPT工具,AI格式优化推荐

8 个自考答辩PPT工具&#xff0c;AI格式优化推荐 在时间与质量的夹缝中挣扎 自考的旅程&#xff0c;从来不是一条轻松的道路。从报名到备考&#xff0c;再到最终的论文撰写和答辩准备&#xff0c;每一个环节都充满了挑战。尤其是当毕业答辩临近时&#xff0c;许多自考生都会面临…

作者头像 李华