news 2026/5/8 22:05:15

【算法专题训练】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/5/5 19:50:50

Langflow本地部署:环境隔离与快速安装

Langflow本地部署&#xff1a;环境隔离与快速安装 在AI应用开发日益普及的今天&#xff0c;如何快速验证一个基于LangChain的智能体或工作流构想&#xff0c;成了许多开发者面临的实际问题。写一堆样板代码&#xff1f;反复调试依赖版本&#xff1f;这些传统方式不仅耗时&…

作者头像 李华
网站建设 2026/5/4 19:59:22

8 个MBA论文工具推荐,AI降重查重率优化方案

8 个MBA论文工具推荐&#xff0c;AI降重查重率优化方案 论文写作的“三座大山”&#xff1a;时间、重复率与效率 对于MBA学生而言&#xff0c;撰写高质量的论文不仅是学术能力的体现&#xff0c;更是职业发展的关键一步。然而&#xff0c;在实际操作中&#xff0c;许多同学常常…

作者头像 李华
网站建设 2026/5/2 3:42:06

10 个AI论文工具,继续教育学员轻松写完毕业论文!

10 个AI论文工具&#xff0c;继续教育学员轻松写完毕业论文&#xff01; AI 工具助力论文写作&#xff0c;让学术之路更轻松 在继续教育的道路上&#xff0c;撰写毕业论文往往是学员们最头疼的任务之一。面对繁重的写作压力、复杂的格式要求以及严格的查重要求&#xff0c;许多…

作者头像 李华
网站建设 2026/5/2 18:48:42

8 个自考论文降重工具,AI查重率优化推荐

8 个自考论文降重工具&#xff0c;AI查重率优化推荐 论文写作的“重灾区”&#xff1a;时间紧、任务多、降重难 自考学子在完成期末论文时&#xff0c;常常面临一个难以回避的现实——任务繁重、时间紧迫&#xff0c;而论文的质量和重复率又直接影响最终成绩。尤其是在文献综述…

作者头像 李华
网站建设 2026/4/26 6:47:14

如何在 CentOS 上设置 Apache Worker MPM ?

Apache HTTP 服务器是世界上使用最广泛的 web 服务器之一&#xff0c;并可按不同方式配置&#xff0c;以满足各种需求。Apache 多处理模块&#xff08;Multi-Processing Module&#xff0c;MPM&#xff09;是一个管理 Apache 服务器进程的模块。Prefork 和 Worker 是目前最流行…

作者头像 李华
网站建设 2026/5/2 5:55:16

芯片失效分析

芯片失效分析总结 芯片失效分析是一门结合材料科学、电子工程、物理学和化学的综合性学科&#xff0c;其核心目标是定位失效点、确定失效机理、找出失效根因&#xff0c;从而改进设计、工艺和封装&#xff0c;提升产品良率、可靠性和寿命。 一、 核心价值与目的 提升良率&#…

作者头像 李华