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

数据结构——Trie

题目:

维护一个字符串集合,支持两种操作:

  1. I x 向集合中插入一个字符串 x𝑥;
  2. Q x 询问一个字符串在集合中出现了多少次。

共有 N𝑁 个操作,所有输入的字符串总长度不超过 10^5,字符串仅包含小写英文字母。

输入格式

第一行包含整数 N𝑁,表示操作数。

接下来 N𝑁 行,每行包含一个操作指令,指令为 I x 或 Q x 中的一种。

输出格式

对于每个询问指令 Q x,都要输出一个整数作为结果,表示 x𝑥 在集合中出现的次数。

每个结果占一行。

数据范围

1≤N≤2∗10^4

解题分析:

本题是Acwing上的一道模板题,Trie树又叫字典树,就是一个像字典一样的树,可以帮助我们快速查找一个字符串是否出现过。通常采用树的边来代表字母,从根节点到树中的某一个结点表示一个字符串,以下是一张OI Wiki的树图:

在图中,aa,aba,ba,caaa,cab,cba,cc均是字符串。我们通常会在每个字符串末尾打上一个标记,用于查询过程中判断到这个标记时,就可读取为一个字符串,从而达到“字典”的效果。

C++实现如下:

#include <iostream>using namespace std;const int N = 100010;int son[N][26], cnt[N], idx;
char str[N];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];  
}int main()
{int m;cin >> m;while(m--){char op[2];scanf("%s%s", op, str);if(*op == 'I') insert(str);else printf("%d\n", query(str));}return 0;
}
http://www.lryc.cn/news/396825.html

相关文章:

  • 前端根据目录生成模块化路由routes
  • Blender新手入门笔记收容所(一)
  • 修改服务器挂载目录
  • Linux+InternStudio 关卡
  • 如何提升美国Facebook直播的整体体验?
  • flutter项目与原生项目相比,性能比较差的原因
  • 第二周:李宏毅机器学习笔记
  • 搜维尔科技:【研究】Scalefit是一款可在工作场所自动处理3D姿势分析结果的软件
  • 网络编程:各协议头(数据报格式)
  • SpringBoot报错:The field file exceeds its maximum permitted size of 1048576 bytes
  • C++的介绍与认识
  • Spark源码详解
  • 浅尝Apache Mesos
  • buuctf题目讲解-1
  • 软件测试学习之-ADB命令
  • Redis的入门导读(一)
  • H5与小程序:两者有何不同?
  • 计算机视觉、目标检测、视频分析的过去和未来:目标检测从入门到精通 ------ YOLOv8 到 多模态大模型处理视觉基础任务
  • 7月10日学习打卡,环形链表+栈OJ
  • 鸿蒙语言基础类库:【@ohos.util.TreeSet (非线性容器TreeSet)】
  • freemarker生成pdf,同时pdf插入页脚,以及数据量大时批量处理
  • 勇攀新高峰|暴雨信息召开2024年中述职工作会议
  • C++:filter2D函数简要概述
  • Postman使用教程【项目实战】
  • 微软Phi-3:小型而强大的AI模型解析与实战指南
  • Python 获取 SQL 指纹和 HASH 值
  • 基于OpenCv的快速图片颜色交换,轻松实现图片背景更换
  • 在Linux下直接修改磁盘镜像文件的内容
  • ASP.NET Core----基础学习03----开发者异常页面 MVC工作原理及实现
  • jvm 07 GC算法,内存池,对象内存分配