新闻中心

C++怎么实现一个Trie树(字典树)_C++数据结构与Trie树实现方法

2025-11-15
浏览次数:
返回列表
答案:Trie树通过节点数组实现字符串高效插入、查找与前缀匹配,支持自动补全等应用,需注意isEnd标记和内存管理。

c++怎么实现一个trie树(字典树)_c++数据结构与trie树实现方法

实现一个Trie树(字典树)在C++中主要用于高效地处理字符串的插入、查找和前缀匹配。它常用于自动补全、拼写检查、IP路由等场景。下面是一个简洁、实用的Trie树实现方法。

基本结构设计

每个Trie节点包含一个布尔值表示是否为某个字符串的结尾,以及一组指向子节点的指针。使用数组或map存储子节点,这里用大小为26的指针数组(假设只处理小写字母)。

struct TrieNode {
    bool isEnd;
    TrieNode* children[26];
<pre class='brush:php;toolbar:false;'>TrieNode() {
    isEnd = false;
    for (int i = 0; i < 26; ++i) {
        children[i] = nullptr;
    }
}

};

插入字符串

从根节点开始,对每个字符计算其在数组中的索引(如 ch - 'a'),若对应子节点不存在则创建新节点。遍历完所有字符后,标记最后一个节点为结束节点。

Reachout.ai Reachout.ai

一个AI驱动的视频开发平台,专为忙碌的企业家和销售团队打造

Reachout.ai 142 查看详情 Reachout.ai
void insert(TrieNode* root, const string& word) {
    TrieNode* node = root;
    for (char ch : word) {
        int idx = ch - 'a';
        if (!node->children[idx]) {
            node->children[idx] = new TrieNode();
        }
        node = node->children[idx];
    }
    node->isEnd = true;
}

查找完整字符串

逐字符向下查找,若中途遇到空指针说明字符串不存在。如果顺利走完且最后一个节点标记为isEnd,则说明存在该字符串。

bool search(TrieNode* root, const string& word) {
    TrieNode* node = root;
    for (char ch : word) {
        int idx = ch - 'a';
        if (!node->children[idx]) {
            return false;
        }
        node = node->children[idx];
    }
    return node->isEnd;
}
</font><H3>查找前缀是否存在</H3><p>与查找字符串类似,但不需要判断isEnd。只要能完整遍历前缀的所有字符,就说明存在该前缀。</p><font color="#0000FF"><pre class="brush:php;toolbar:false;">
bool startsWith(TrieNode* root, const string& prefix) {
    TrieNode* node = root;
    for (char ch : prefix) {
        int idx = ch - 'a';
        if (!node->children[idx]) {
            return false;
        }
        node = node->children[idx];
    }
    return true;
}

整个Trie类可以封装成一个类,便于管理内存和调用接口。注意实际项目中建议添加析构函数释放动态分配的节点,避免内存泄漏。这个实现方式简单清晰,适合大多数基础应用场景。基本上就这些,不复杂但容易忽略细节比如isEnd的设置。

以上就是C++怎么实现一个Trie树(字典树)_C++数据结构与Trie树实现方法的详细内容,更多请关注其它相关文章!


# 相关文章  # 榆次网络营销推广好处  # 网站搜索优化算法公式  # 北京网站seo优化建设  # 网页如何优化权重网站  # 锦州优化网站软件  # 企业seo工作计划  # 描述模板网站建设ppt  # 武汉seo服务精准获客  # 安庆海外网站优化  # 洛江引流推广线上营销  # 解决问题  # 中文网  # c++  # 是一个  # 正确处理  # 如何处理  # 尼克  # 不存在  # 遍历  # 数据结构  # 路由  # node  # word  # trie树 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 深入理解J*a链表中的IPosition接口与使用  解决深度学习模型训练初期异常高损失与完美验证准确率问题  Win10自动更新怎么关闭 Win10永久关闭系统更新的两种方法【终极版】  MinIO大规模对象列表性能瓶颈深度解析与外部元数据管理策略  三星GalaxyZFold5怎样在相册制作折叠屏分镜_iPhone三星GalaxyZFold5相册制作折叠屏分镜【创意编辑】  CSS图片焦点样式实现教程:理解与应用tabindex属性  深入理解Promise链:如何在catch后中断then的执行  j*a toString()的覆盖  LocoySpider如何部署到云服务器_LocoySpider云部署的远程配置  如何为你的Composer包编写自动化测试_集成PHPUnit到Composer的scripts工作流  在Socket.IO连接中实现Access Token自动更新与动态重连  sublime如何只显示或隐藏特定类型文件_sublime侧边栏文件过滤  高德地图家和公司地址在哪设置 高德地图通勤路线设置方法【超详细】  qq游戏免费畅玩入口_qq游戏电脑版快速启动  内存疯狂猛猛涨价:主板销量直接腰斩!  深入理解与实现最大堆的Heapify过程:常见错误与修正  Highcharts 雷达图径向轴标签定制指南:利用多Y轴实现数值标注  在Qt QML中通过Python字典动态更新TextEdit内容的教程  J*aScript中高效清空DOM列表元素:解决for循环中断与任务管理问题  顺丰快递查询系统 官方正版查询入口  深入理解字体排版:Adobe光学字偶距与CSS字偶距的差异与实现  解决移动端滚动问题的overflow属性应用指南  J*aScript实现动态背景色下的文本与按钮颜色自适应调整  Angular响应式表单:实现提交后表单及按钮的禁用与只读化  解决 Vaadin 8 中大文件音频播放与定位时出现的 IOException  百度网盘网页版入口 百度网盘网页版官方登录网址  Android Studio计算器C键功能异常排查与修复教程  c++如何实现单例设计模式_c++线程安全的单例模式写法  聚水潭ERP登录页面入口 聚水潭ERP官网登录界面  如何在Python中使用Optional类型处理可变对象并避免Pylint警告  J*aScript:在map操作中高效处理空数组  2026春节假期票务安排_2026春节放假购票指南  J*aScript中如何高效提取对象指定属性  包子漫画官方网站阅读入口-包子漫画在线漫画官网直达链接  凉拌黄瓜怎么拌更入味 凉拌黄瓜简单家常做法  J*aScript中高效管理与清空动态列表:避免循环陷阱  《主播少女的秘密账号迷宫》首支宣传片  如何在CSS中使用浮动制作导航栏_float实现水平菜单  UC浏览器网页版登录入口官网 电脑版网址入口  Win10文件资源管理器“此电脑”分组怎么关 Win10恢复经典视图【技巧】  微博网页版官方账号登录 微博网页版内容浏览使用指南  PowerPoint如何制作滚动字幕结尾彩蛋_PowerPoint路径动画实现平滑滚动字幕效果  俄罗斯浏览器官网直达链接 俄罗斯浏览器最新在线入口导航  铁路12306改签能改到更早的车次吗_铁路12306改签提前车次规则  荒野行动PC版怎么注册_荒野行动PC版账号注册详细流程图文教程  Win11怎么设置鼠标指针速度_Win11提高鼠标指针精确度选项  在J*a中如何开发在线活动报名与管理系统_活动报名管理项目实战解析  在J*a中如何开发简易电子商务商品管理系统_商品管理系统项目实战解析  如何有效阻止外部脚本意外修改内联样式的高度属性  CSS Flexbox与媒体查询:实现响应式布局中元素的并排与堆叠 

搜索