http://codevs.cn/problem/2403/

2012年省队选拔赛四川

 时间限制: 2 s
 空间限制: 128000 KB
 
题目描述 Description

a180285幸运地被选做了地球到喵星球的留学生。他发现喵星人在上课前的点名现象非常有趣。 
假设课堂上有 N 个喵星人,每个喵星人的名字由姓和名构成。喵星球上的老师会选择M 个串来点名,每次读出一个串的时候,如果这个串是一个喵星人的姓或名的子串,那么这个喵星人就必须答到。 
然而,由于喵星人的字码过于古怪,以至于不能用 ASCII 码来表示。为了方便描述,a180285决定用数串来表示喵星人的名字。 
现在你能帮助 a180285 统计每次点名的时候有多少喵星人答到,以及 M 次点名结束后每个喵星人答到多少次吗?

 
输入描述 Input Description

现在定义喵星球上的字符串给定方法: 
先给出一个正整数 L,表示字符串的长度,接下来L个整数表示字符串的每个字符。 
输入的第一行是两个整数N和M。 
接下来有N行,每行包含第 i个喵星人的姓和名两个串。姓和名都是标准的喵星球上的字符串。 
接下来有M行,每行包含一个喵星球上的字符串,表示老师点名的串。

 
输出描述 Output Description

对于每个老师点名的串输出有多少个喵星人应该答到。 
然后在最后一行输出每个喵星人被点到多少次。

 
样例输入 Sample Input

2 3 
6 8 25 0 24 14 8 6 18 0 10 20 24 0 
7 14 17 8 7 0 17 0 5 8 25 0 24 0 
4 8 25 0 24 
4 7 0 17 0 
4 17 0 8 25

 
样例输出 Sample Output




1 2

 
数据范围及提示 Data Size & Hint

对于30%的数据,保证: 
1 <= M, N <= 1000
喵星人的名字总长不超过 4000,点名串的总长不超过 2000, 
对于100%的数据,保证: 
1<=N<=20000
1<=M<=50000
喵星人的名字总长和点名串的总长分别不超过
100000 保证喵星人的字符串中作为字符存在的数不超过 10000

AC自动机

学了几招:

1、用map搞trie

2、bool数组初始化,数组很大,需清空的数目不多,用vector记下来,枚举vector里的元素,清零

(貌似CDQ分治、整体二分就是这样搞的)

#include<iostream>
#include<cstdio>
#include<queue>
#include<map>
#include<vector>
#define N 100010
using namespace std;
map<int,int>trie[N];
vector<int>a[],st[N],USE,MARK;
int f[N];
int len,tot=,n,m;
queue<int>q;
bool mark[N],use[];
int call[],miao[];
struct aa
{
void insert(int i)
{
int x,root=;
while(len--)
{
scanf("%d",&x);
if(!trie[root][x]) trie[root][x]=++tot;
root=trie[root][x];
}
st[root].push_back(i);
}
void getfail()
{
q.push();int j;
while(!q.empty())
{
int now=q.front();q.pop();
map<int,int>::iterator it;
for(it=trie[now].begin();it!=trie[now].end();it++)
{
int w=it->second,e=it->first;
q.push(w);
j=f[now];
while(!trie[j][e]) j=f[j];
f[w]=trie[j][e];
}
}
}
void get(int now,int who)
{
for(int i=now;i;i=f[i])
{
if(mark[i]) return;
else
{
mark[i]=true;
MARK.push_back(i);
for(int j=;j<st[i].size();j++)
{
if(!use[st[i][j]])
{
use[st[i][j]]=true;
USE.push_back(st[i][j]);
miao[who]++;
call[st[i][j]]++;
}
}
}
}
}
void solve(int k)
{
int id,root=;
for(int i=;i<a[k].size();i++)
{
id=a[k][i];
while(!trie[root][id]) root=f[root];
root=trie[root][id];
get(root,k);
}
for(int i=;i<MARK.size();i++) mark[MARK[i]]=false;
for(int i=;i<USE.size();i++) use[USE[i]]=false;
MARK.clear();USE.clear();
}
}tree;
int main()
{
/*freopen("name.in","r",stdin);
freopen("name.out","w",stdout);*/
int x;
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)
{
scanf("%d",&len);
while(len--)
{
scanf("%d",&x);
a[i].push_back(x);
}
a[i].push_back(-);
scanf("%d",&len);
while(len--)
{
scanf("%d",&x);
a[i].push_back(x);
}
}
for(int i=;i<=m;i++)
{
scanf("%d",&len);
tree.insert(i);
}
for(int i=-;i<=;i++) trie[][i]=;
tree.getfail();
for(int i=;i<=n;i++)
tree.solve(i);
for(int i=;i<=m;i++) printf("%d\n",call[i]);
for(int i=;i<n;i++) printf("%d ",miao[i]);printf("%d",miao[n]);
return ;
}

SCOI2012喵星球上的点名的更多相关文章

  1. BZOJ 2754: [SCOI2012]喵星球上的点名

    2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 649  Solved: 305[Submit][Sta ...

  2. BZOJ2754: [SCOI2012]喵星球上的点名

    2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 680  Solved: 314[Submit][Sta ...

  3. BZOJ 2754: [SCOI2012]喵星球上的点名 [后缀数组+暴力]

    2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1906  Solved: 839[Submit][St ...

  4. BZOJ 2754: [SCOI2012]喵星球上的点名 [AC自动机+map+暴力]

    2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1902  Solved: 837[Submit][St ...

  5. P2336 [SCOI2012]喵星球上的点名(后缀自动机+莫队+dfs序)

    P2336 [SCOI2012]喵星球上的点名 名字怎么存?显然是后缀自动机辣 询问点到多少个喵喵喵其实就是 查询后缀自动机上parent树的一个子树 于是我们考虑莫队 怎么树上莫队呢 我们用dfs序 ...

  6. 洛咕 P2336 [SCOI2012]喵星球上的点名

    洛咕 P2336 [SCOI2012]喵星球上的点名 先求出SA和height,一个点名串对应的就是一段区间,还有很多个点,就转化成了 有很多个区间,很多个点集,对每个区间计算和多少个点集有交,对每个 ...

  7. 洛谷 P2336 [SCOI2012]喵星球上的点名 解题报告

    P2336 [SCOI2012]喵星球上的点名 题目描述 a180285 幸运地被选做了地球到喵星球的留学生.他发现喵星人在上课前的点名现象非常有趣. 假设课堂上有 \(N\) 个喵星人,每个喵星人的 ...

  8. 【BZOJ2754】[SCOI2012]喵星球上的点名

    [BZOJ2754][SCOI2012]喵星球上的点名 题面 bzoj 洛谷 题解 这题有各种神仙做法啊,什么暴力\(AC\)自动机.\(SAM\)等等五花八门 我这个蒟蒻在这里提供一种复杂度正确且常 ...

  9. 2754. [SCOI2012]喵星球上的点名【后缀数组】

    Description a180285幸运地被选做了地球到喵星球的留学生.他发现喵星人在上课前的点名现象非常有趣.   假设课堂上有N个喵星人,每个喵星人的名字由姓和名构成.喵星球上的老师会选择M个串 ...

随机推荐

  1. 软工1816 · Beta冲刺(3/7)

    团队信息 队名:爸爸饿了 组长博客:here 作业博客:here 组员情况 组员1(组长):王彬 过去两天完成了哪些任务 协助后端完成历史记录接口.美食排行榜接口 完成食堂平面图的绘制 确定web端业 ...

  2. B2

    组员1:吴晓晖(组长) 过去两天完成了哪些任务 代码重构基本完成 展示GitHub当日代码/文档签入记录 接下来的计划 推荐算法 还剩下哪些任务 组员2:陈锦谋 过去两天完成了哪些任务 重新制作图标 ...

  3. 29_Java_数据库_第29天(JDBC、DBUtils)_讲义

    今日内容介绍 1.JDBC 2.DBUtils 01JDBC概念和数据库驱动程序 * A: JDBC概念和数据库驱动程序 * a: JDBC概述 * JDBC(Java Data Base Conne ...

  4. Redis&PHP的使用安装-windows版

    Redis是一个Key-value的数据结构存储系统,可以以数据库的形式,缓存系统,消息处理器使用,它支持的存储value类型很多,例如,string.list(链表).set(集合).zset(so ...

  5. ClientDataSet字段不能进行编辑时的解决方法

    ClientDataSet字段不能进行编辑时的解决方法: procedure ModifyClientDataSet(const YesOrNot: Boolean;  cs : TClientDat ...

  6. python3 执行AES加密方法

    cmd执行命令:pip install pycryptodome # -*- coding: utf-8 -*- # __author__ = 'Carry' import base64 from C ...

  7. React之智能组件和木偶组件

    智能组件 VS 木偶组件 在 React + Redux 结合作为前端框架的时候,提出了一个将组件分为“智能”和“木偶”两种 智能组件:它是数据的所有者,它拥有数据.且拥有操作数据的action,但是 ...

  8. C语言中变量名及函数名的命名规则与驼峰命名法

    一.C语言变量名的命名规则:(可以字母,数字,下划线混合使用) 1. 只能以字母或下划线开始:2. 不能以数字开始:3. 一般小写:4. 关键字不允许用(eg:int float=2//error  ...

  9. 为什么家里的宽带的IP显示的是外地?

    作者:NightCoffee链接:https://www.zhihu.com/question/22547945/answer/21734955来源:知乎著作权归作者所有.商业转载请联系作者获得授权, ...

  10. MT【160】格点

    (2017年清华大学  THUSSAT) 把不超过实数 $x$ 最大整数记为 $[x]$,任取互质且不小于 3 的正奇数 $m,n$,令$$I=\sum_{i=1}^{\frac{m-1}{2}}\l ...