理解前缀树

简介: 理解前缀树

Prefix tree

前缀树实现

class Node
{
    public int pass;
    public int end;
    public Node[] nexts;
    /******也可以用哈希表******/
    public Node()
    {
        pass = 0;
        end = 0;
        nexts = new Node[26];
    }
};
class Tris
{
    private Node root;
    public Tris(){root = new Node(); }
    public void Insert(string str)
    {
        if(str == null)
        {
            return;
        }
        char[] chs = str.toCharArray();
        Node node = root;
        node.pass++;
        int index = 0;
        for(int i = 0;i < charr.size(); i++)
        {
            index = chs[i] - 'a';
            if(node.nexts[index] == null)
            {
                node.nexts[index] = new Node();
            }
            node = node.nexts[index];
            node.pass++;
        }
        node.end++;
    }
    public void Desert(string str)
    {
        if(!Search(str)) return;
        char[] chs = str.toCharArray();
        Node node = root;
        int index = 0;
        node.pass--;
        for(int i = 0;i < chs.size(); i++)
        {
            index = chs[i] - 'a';
            if(--node.nexts[index].pass == 0)
            {
                node.nexts[index] = null;
                return;
                /******c++需要手动遍历释放节点******/
            }
            node = node.nexts[index];
        }
        node.end--;
    }
    public boolean Search(string str)
    {
        if(str == null) return true;
        char[] chs = str.toCharArray();
        Node node = root;
        int index = 0;
        for(int i = 0;i < chs.size(); i++)
        {
            index = chs[i] - 'a';
            if(node.nexts[index] == null) return false;
            node = node.nexts[index];
        }
        return node.end > 0;
    }
    /******查找有多少以str为前缀的字符串******/
    public int SearchPre(string str)
    {
        if(str == null) return 0;
        Node node = root;
        int index = 0;
        char[] chs = str.toCharArray();
        for(int i = 0;i < chs.size();i++)
        {
            index = chs[i] - 'a';
            if(node.nexts[index] == null) return 0;
            node = node.nexts[index];
        }
        return node.pass;
    }
}


目录
相关文章
|
存储 算法 C语言
树模板总结
树模板总结
140 0
|
10月前
|
供应链 区块链
探索区块链技术在供应链管理中的应用与挑战
本文深入探讨了区块链技术在现代供应链管理中的创新应用及其面临的挑战。通过分析区块链的去中心化特性、不可篡改性以及透明度,阐述了如何利用这一技术优化供应链流程,提高数据共享的安全性与效率。同时,文章也指出了实施过程中的技术难题、成本考量及法规限制等挑战,为读者提供了对区块链技术在供应链领域应用前景的全面认识。
|
11月前
|
Ubuntu jenkins 持续交付
Ubuntu系统 用docker安装jenkins
Ubuntu系统 用docker安装jenkins
|
XML 数据格式
Office Tool Plus v10.10.7.0
Office Tool Plus(简称OTP)是一款微软Office办公软件下载、安装、管理的辅助增强工具。它可以快速自定义部署,在线下载安装 Office 的各个版本,也可以通过已有的离线安装文件来部署Office镜像,同时在安装过程中你可以自由选择安装哪些需要使用的组件, 在安装之后也可以单独来安装某个需要的组件。
265 2
|
数据采集
做个爬虫吧:豆瓣《八佰》影评
做个爬虫吧:豆瓣《八佰》影评
105 0
如何注册阿里云服务器
首先第一步,注册一下阿里云账号吧。其次第二步,实名一下阿里云账号。
如何注册阿里云服务器
|
容灾
《云上容灾交付服务白皮书》——4.交付标准化评估要素——4.1 需求分析的评估要素
《云上容灾交付服务白皮书》——4.交付标准化评估要素——4.1 需求分析的评估要素
121 0
|
存储 JSON 缓存
【小家Spring】Redis序列化、RedisTemplate序列化方式大解读,介绍Genericjackson2jsonredisserializer序列化器的坑(上)
【小家Spring】Redis序列化、RedisTemplate序列化方式大解读,介绍Genericjackson2jsonredisserializer序列化器的坑(上)
【小家Spring】Redis序列化、RedisTemplate序列化方式大解读,介绍Genericjackson2jsonredisserializer序列化器的坑(上)
|
JavaScript 索引
vue之vue2.x基础知识
vue之vue2.x基础知识
214 0
vue之vue2.x基础知识