模拟Trie树结构

简介: 模拟Trie树结构

Trie树的概念


Trie树是数据结构比较简单的一种。Trie 树的基本用法是高效的存储和查找字符串集合的数据结构。Trie树也叫做字典树,它是一个树形结构。是一种专门处理字符串匹配的数据结构,用来解决在一组字符串集合中快速查找某个字符串。Trie树本质,利用字符串之间的公共前缀,将重复的前缀合并在一起。


例如:


插入


abcdef


abdef


aced


bcdf


bcff


cdaa


bcdc


abc


1.首先插入abcdef


先判断根节点有没有a这个点作为子节点,没有就创建出来,以此类推,再从a往下走,判断a有没有b这个子节点,没有就创建出来,以此类推,把剩下的插入进来,(存的时候会在结尾的单词后面打上一个标记,表示在这个字母结尾是有一个的单词的)如图:



2.依次插入其他


最终结果


模板:


    static int N=100010;
    static int [][]son=new int[N][26];  //son[][]存储树中每个节点的子节点
    static int []cnt=new int[N];        //记录以每个结点结尾的单词数量
    static int idx;         //当前用的的哪个下标,下标0:既是根节点又是空节点
    //插入操作
    public static void insert(char []str){
        int p=0;//根节点
        for (int i = 0; i < str.length; i++) {//从根节点开始依次遍历
            int x=str[i]-'a';//把当前这个节点的下标取出来
            //如果当前这个点上不存在对应的字母的话,创建出来
            if(son[p][x]==0){
              son[p][x]=++idx;
            }
            //走到下一个点,p可以理解为父节点
            p=son[p][x];
        }
        cnt[p]++; //记录下这个单词出现次数
    }
    //查询操作
   public static int query(char []str){
       int p=0;
       for (int i = 0; i < str.length; i++) {
           int x=str[i]-'a';
           //如果不存在这个子节点的话,说明集合中不存在这个单词
           if(son[p][x]==0) return 0;
           p=son[p][x];
       }
       return cnt[p];
   }


相关文章
|
安全 数据挖掘 Linux
Linux命令rpm深度解析
`rpm`是Linux下的软件包管理器,用于安装、升级、卸载和查询`.rpm`包,常见于Red Hat系Linux。它管理依赖、维护软件信息数据库,支持版本控制和安全验证。常用命令如`-i`安装,`-U`升级,`-e`卸载,`-q`查询。安装时用`-v`和`-h`可查看详细信息和进度。注意依赖关系、权限和签名验证,最佳实践包括使用仓库、定期更新和备份数据。
|
存储 Unix C++
c++时间形式转换
【10月更文挑战第29天】在 C++ 中,时间形式转换主要涉及将时间在不同表示形式之间转换,如字符串与 `tm` 结构或 `time_t` 类型之间的转换。常用的基本时间类型包括 `time_t` 和 `tm` 结构,转换函数有 `strftime` 和 `strptime`,可以满足大多数时间处理需求。此外,还可以通过自定义类来扩展时间转换功能。
351 0
|
测试技术 UED
软件测试中的探索性测试:一种高效且灵活的测试方法
本文将深入探讨探索性测试的核心概念、优势及其在实际项目中的应用。我们将从探索性测试的基本定义入手,逐步解析其在不同场景下的具体实施方法和最佳实践。通过详细的案例分析和方法对比,帮助读者全面了解这种既高效又灵活的软件测试技术。
|
存储 传感器 编解码
【Camera基础(二)】摄像头驱动原理和开发&&V4L2子系统驱动架构
【Camera基础(二)】摄像头驱动原理和开发&&V4L2子系统驱动架构
|
存储 弹性计算 运维
多行注释
【4月更文挑战第29天】
119 2
|
安全 新能源 数据挖掘
新能源汽车企业投资价值分析_kaic
新能源汽车企业投资价值分析_kaic
|
存储 传感器 安全
【软件设计师备考 专题 】描述软件需求的多种方法
【软件设计师备考 专题 】描述软件需求的多种方法
315 0
|
安全 开发工具
微信小游戏制作工具中的键盘插件的使用
微信小游戏制作工具中的键盘插件的使用
1063 0
|
前端开发 JavaScript 程序员
如何做好IT类的技术面试
如何做好IT类的技术面试
ffmpeg实战将视频转换为图片
ffmpeg实战将视频转换为图片
439 0
ffmpeg实战将视频转换为图片

热门文章

最新文章