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

Trie树算法

Trie树,也称为前缀树或字典树,是一种特殊的树型数据结构。它用于存储一组字符串,使得查找、插入和删除字符串的操作非常高效。类似这种,

模板:

这是用数组来模拟上图中的树的结构,逻辑上和上图结构一致。

大家一定要手动看代码模拟一边,只靠想象不光浪费时间还想不明白。

int son[N][26], cnt[N], idx;
// 0号点既是根节点,又是空节点,这里0号点指的是idx
// son[][]存储树中每个节点的子节点
// cnt[]存储以每个节点结尾的单词数量

// 插入一个字符串
void insert(char *str)
{
    int p = 0;
    for (int i = 0; str[i]; i ++ )
    {
        int u = str[i] - 'a';
        if (!son[p][u]) son[p][u] = ++ idx;
        p = son[p][u];
    }
    cnt[p] ++ ;
}

// 查询字符串出现的次数
int query(char *str)
{
    int p = 0;
    for (int i = 0; str[i]; i ++ )
    {
        int u = str[i] - 'a';
        if (!son[p][u]) return 0;
        p = son[p][u];
    }
    return cnt[p];
}


http://www.kler.cn/a/505664.html

相关文章:

  • 网络技术发展的演变与未来展望
  • sql_实用查询语句模版
  • 深入浅出 Android AES 加密解密:从理论到实战
  • 逻辑测试题
  • BUUCTF:misc刷题记录4(会持续更新的)
  • 对MySQL滴MVCC理解(超详细)
  • 1月13日学习
  • 安全开发 javaEE应用 servlet 路由技术 生命周期 JDBC数据库操作
  • Centos9-SSH免密登录配置-修改22端口-关闭密码登录-提高安全性
  • 服务端渲染(SSR)与客户端渲染(CSR)详解
  • 8.User-Agnet代理池
  • 链家房价数据爬虫和机器学习数据可视化预测
  • 解决 Git SSL 连接错误:OpenSSL SSL_read: SSL_ERROR_SYSCALL, errno
  • 【嵌入式——Linux】Ubuntu网络环境配置
  • 【大厂面试AI算法题中的知识点】方向涉及:ML/DL/CV/NLP/大数据...本篇介绍自动驾驶检测模型如何针对corner case 优化?
  • 个人主页搭建全流程(Nginx部署+SSL配置+DCDN加速)
  • 《鸿蒙开发-鸿蒙教程-答案之书》组件margin左和右等于没偏?
  • LeetCode第432场周赛 (前3题|多语言)
  • 如何使用插件(刷课,游戏等)
  • Sonatype Nexus OSS 构建私有docker 仓库
  • 拆分工作簿转换PDF格式文件一步到位-Excel易用宝
  • PHP深度学习探索
  • AI数字人小程序:解锁个性化智能交互体验
  • Spring WebFlux 高级实战(3-3)
  • android Recyclerview viewholder统一封装
  • Android Auto能够与Android设备整合的几项功能有哪些?