首页 > 其他分享 >字典树

字典树

时间:2024-04-16 17:38:00浏览次数:29  
标签:cnt const int son ++ 字符串 字典

简介

字典树是一种用来维护多个字符串的前缀的数据结构,时空复杂度均为 \(O(\sum |S|)\)。

字典树是一颗外向树(边从父亲连向儿子),每条边的边权都为一个字符,一个结点对应的字符串为从根节点到当前结点的边的字符组成的字符串。

比如,当 \(N=5\),\(S_1,S_2,\dots,S_5\) 分别为 akaoiaeriao 时字典树如下:

其中黑色的代表对应字符串,红色的代表这个字符串作为前缀的出现次数。

注:\0 指空字符。

插入

枚举字符串的每个字符,如果当前结点有一条边的字符等于当前字符,就走到对应儿子;否则就创建一个新结点并建边,再走到那个儿子。途中将经过的点的出现次数加 \(1\)。

单次时间复杂度 \(O(|S|)\)。

代码

void Insert(const string &s) {
  int u = 1;
  for(char c : s) {
    if(!son[u][c]) {
      son[u][c] = ++tot;
    }
    cnt[u]++;
    u = son[u][c];
  }
  cnt[u]++;
}

Insert(s);

查询

同样的,枚举字符串的每个字符,每次走到对应边上,如果没有直接返回 \(0\)。

单次时间复杂度 \(O(|S|)\)

代码

int Getsum(const string &s) {
  int u = 1;
  for(char c : s) {
    if(!son[u][c]) {
      return 0;
    }
    u = son[u][c];
  }
  return cnt[u];
}

Getsum(s);

代码

#include<bits/stdc++.h>
using namespace std;

const int MAXN = 1001;

struct Trie {
  int tot = 1, cnt[MAXN], son[MAXN][256];
  void Insert(const string &s) {
    int u = 1;
    for(char c : s) {
      if(!son[u][c]) {
        son[u][c] = ++tot;
      }
      cnt[u]++;
      u = son[u][c];
    }
    cnt[u]++;
  }
  int Getsum(const string &s) {
    int u = 1;
    for(char c : s) {
      if(!son[u][c]) {
        return 0;
      }
      u = son[u][c];
    }
    return cnt[u];
  }
}tr;

int n, m;

int main() {
  ios::sync_with_stdio(false), cin.tie(0), cout.tie(0);
  cin >> n >> m;
  for(int i = 1; i <= n; ++i) {
    string s;
    cin >> s;
    tr.Insert(s);
  }
  for(int i = 1; i <= m; ++i) {
    string s;
    cin >> s;
    cout << tr.Getsum(s) << "\n";
  }
  return 0;
}

标签:cnt,const,int,son,++,字符串,字典
From: https://www.cnblogs.com/yaosicheng124/p/18138744

相关文章

  • 异常捕获列表字典推导式
    【一】什么是异常异常是程序运行时可能发生的错误或意外情况。在Python中,异常是一种对象,表示程序执行期间发生的错误。当出现异常时,程序的正常流程会被中断,而是跳转到异常处理流程。【二】异常分类在Python中,异常分为两类:内建异常(Built-inExceptions):由Python内部定义的......
  • python-字典的学习
    '''在Python中,字典字是一系列键—值对值。每个键都与一个值相关联,你可以使用键来访问与之相关联的值。与键相关联的值可以是数字、字符串、列表乃至字典。事实上,可将任何Python对象用作字典中的值。在Python中,字典用放在花括号{}中的一系列键—值对表示'''customer={'name......
  • 针对列表中的字典去重
    背景:我有一个列表,列表中存储的子元素是字典,字典中存在多个键值对,其中id是绝对不相同的,但其他键值对可能和另外的子元素重复,现在要去除重复的子元素#原始列表original_list=[{"id":1,"name":"Alice","age":20},{"id":2,"name":"Bob","age&q......
  • python基础-数据类型、字典、集合、文件操作(打开、关闭、读写、追加等)
    前言!!!注意:本系列所写的文章全部是学习笔记,来自于观看视频的笔记记录,防止丢失。观看的视频笔记来自于:哔哩哔哩武沛齐老师的视频:​​2022Python的web开发(完整版)入门全套教程,零基础入门到项目实战​数据结构数据类型字符串列表元组集合字典整型布尔None浮点型字节类......
  • 文档操作&异常捕获&列表、字典推导式
    【零】文档操作【1】读和写(覆盖写和追加写)#r(read):只读模式#将数据一次性全部读出#w(write):只写模式#如果文件存在则打开文件,并将文件内荣清空然后写入新的内容#如果文件不存在则新建文件,并写入新的内容#a(append):追加写模式#如果文件存在则打开文件,而......
  • 第 9 场 小白入门赛 字典树考试
    题目:4.字典树考试【算法赛】-蓝桥云课(lanqiao.cn)思路:我们可以先抛开题目,想一下一个二进制数是111111111 --->9个1,题目说(Ai&Aj)所以两个1一个组合,我们用最笨的方式取枚举----->是8+7+6+5+.......+1是36两两一组,想想X个1如何算呢?是不是应......
  • Linux架构28 ansible流程控制, 条件判断(主机,是否安装,系统版本), 循环语句(安装启动
    Ansible流程控制一、playbook条件语句不管是shell还是各大变成语言中,流程控制,条件判断这些都是必不可少的,在我们使用Ansible的过程中,条件判断的使用频率极其高。例如:1.我们使用不同的系统的时候,可以通过判断系统来对软件包进行安装。2.在nfs和rsync安装过程中,客户端服务器......
  • 列表、字典推导式
    列表推导式固定语法:[表达式foriinlist/dict...判断语句][if语句foriinlist/dict...][字符串处理foriinlist/dict...]name_list=['a','b']name_new=['nb_'+iforiinname_list]print(name_new)字典推导式固定语法:[key:value......
  • day02元组-集合-字典
    元组 概念元组:由一系列变量组成的不可变序列容器序列:支持索引和切片不可变:1.没有增删改的方法2.所有的操作都不会直接作用于原数据 定义<spanstyle="font-size:16px;"data-mce-style="font-size:16px;">元组tuple()#1.定义多......
  • 【go从入门到精通】一文把map字典搞得明明白白
    Mapmap是一种元素对的无序集合,一组称为元素value,另一组为唯一键索引key。未初始化map的值为nil。map是引用类型,可以使用如下声明:varmap1map[keytype]valuetype([keytype]和valuetype之间允许有空格,但是Gofmt移除了空格)在声明的时候不需要知道map的长度,map是可......