当前位置: 首页 > news >正文

【算法专题训练】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
  • 前缀树的创建与查询,将单词插入到前缀树中,根据单词的字符查找对应位置的结点是否存在,不存在的话则新建结点,并重新赋值。
  • 单词查询方式也一样的逻辑,根据遍历到的字符位置查找结点,直到单词结尾的结点,并判断是否有结束标识。
http://www.cnnetsun.cn/news/90676.html

相关文章:

  • 【Dify高性能视频处理指南】:精准帧率设置提升提取速度300%
  • 为什么你的Tesseract在Dify中处理慢?这5个批量优化关键点必须掌握
  • CDM(充电器件模型)导致芯片失效原因
  • IL-2:调控免疫稳态的“双面因子”
  • 【环境风险评估效能革命】:基于R语言的动态监测系统搭建实录
  • 揭秘Dify中PDF加密与权限验证机制:企业级数据防护必备技能
  • 酒精饮料市场:挑战中寻找机遇 eBest
  • 为什么顶尖数据团队都在用R Shiny做多模态报告?真相令人震惊
  • ChatTTS与GPT-SoVITS语音合成对比分析
  • MySQL Shell 使用方法
  • Docker多阶段构建与精简基础镜像(边缘Agent瘦身必看)
  • PPIO上线阿里Wan 2.6:制作电影级AI视频,对标Sora2
  • 【混合检索的Dify结果融合】:揭秘高效信息聚合背后的黑科技
  • 从零搭建高效音频流水线:Dify 1.7.0切片配置完整教程
  • 大数据ETL中的数据质量提升工具与方法
  • 筑巢引凤 - Ascend C开发环境极速部署与验证全攻略
  • 模型训练中的精度保障:Ascend C算子数值稳定性分析
  • 【金融风险对冲实战指南】:掌握R语言在投资组合风险管理中的7大核心技巧
  • 空间转录组批次校正实战指南(R语言完整代码+案例解析)
  • 计算机毕业设计附项目源码帮做/Java管理系统/springboot网站/深度学习/神经网络算法/yolo图像识别/从选题到部署,一篇搞定!
  • 紧急应对模型版本混乱:R与Python部署同步的实时解决方案
  • 气象模型预测失败的真相,R语言误差分析告诉你答案
  • 【Dify 1.7.0语音识别革命】:为什么专业团队都在抢用新转写引擎?
  • 强化学习DeepQLearning求最优策略的代码实现
  • 加密PDF处理新进展(Dify进度跟踪深度剖析)
  • 从零构建智能Agent文档系统:Dify配置与最佳实践全揭秘
  • 高负载环境下Docker Offload调度失控?优先级设置不当是元凶!
  • 还在手动校验语音数据?Dify 1.7.0自动检测功能已上线(限时体验)
  • 专家警告:不掌握量子计算镜像缓存技术,你的研发效率已落后同行三年
  • 对标行业高标准,全星研发项目管理系统赋能汽车芯片研发升级:PLM系统更专业化