题目:Secret Message

老师说的trie树入门题

对于每个密码,存入trie树,每个字符对应编号i,则sum[i]++,最后结尾的编号为j,cnt[j]++

查询,每个字符对应编号为i,不存在直接返回ret,否则,ret+=cnt[i](某个密码是此查询的前缀),最后返回答案ret+sum[j]-cnt[j](cnt[j]已经加过一次,此查询是sum[j]个密码的前缀)

#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
const int N=5e5+5;
using namespace std;
int son[N<<1][2],cnt[N],n,m,a[N],tot,sum[N];
void insert(int len)
{
int p=0;
for(int i=1;i<=len;i++)
{
if(!son[p][a[i]])
son[p][a[i]]=++tot;
p=son[p][a[i]];
sum[p]++;
}
cnt[p]++;
}
int query(int len)
{
int p=0,ret=0;
for(int i=1;i<=len;i++)
{
if(!son[p][a[i]])
return ret;
p=son[p][a[i]];
ret+=cnt[p];
}
return ret+sum[p]-cnt[p];
}
int main()
{
scanf("%d %d",&n,&m);
for(int i=1;i<=n;i++)
{
int len;
scanf("%d",&len);
for(int j=1;j<=len;j++)
scanf("%d",&a[j]);
insert(len);
}
for(int i=1;i<=m;i++)
{
int len;
scanf("%d",&len);
for(int j=1;j<=len;j++)
scanf("%d",&a[j]);
printf("%d\n",query(len));
}
return 0;
}

最新文章

  1. C#如何获取本机网络IP地址
  2. javascript页面加载完执行事件
  3. 「2013-9-5」Configure WingIDE for better display of East Asian Glyphs
  4. Magicodes.WeiChat——自定义knockoutjs template、component实现微信自定义菜单
  5. C++ 必知必会:条款15 成员的指针并非指针
  6. 搜索引擎spam
  7. Redis的Java客户端Jedis的八种调用方式(事务、管道、分布式)介绍
  8. Java基础—ClassLoader的理解(转)
  9. java 测试IP
  10. Leetcode题解(十八)
  11. Beta 冲刺(7/7)
  12. H5 24-CSS三大特性之继承性
  13. LeetCode--No.005 Longest Palindromic Substring
  14. Codeforces 1025 D - Recovering BST
  15. 由于出现以下异常,无法生成模型:“System.Data.StrongTypingException: 表“TableDetails”中列“IsPrimaryKey”的值为 DBNull。
  16. python 基数排序
  17. C++之类和对象的使用(一)
  18. jQuery使用正则判断是否含有非法字符
  19. Websocket、长连接、循环连接
  20. map.containsKey

热门文章

  1. SQL order by 语句对null值排序
  2. 第八十四篇:Vue购物车(五) 商品数量的增减
  3. 如何高效解决 C++内存问题,Apache Doris 实践之路|技术解析
  4. MAC Golang环境搭建
  5. GreatSQL vs MySQL性能测试来了,速围观~
  6. Windows Server体验之SSH远程连接
  7. 【To B产品怎么做?】泛用户体验
  8. C++ 左值引用与 const 关键字
  9. Kubernetes 日志:日志收集架构
  10. Kubernetes 监控--PromQL