SCOI2012喵星球上的点名
http://codevs.cn/problem/2403/
2012年省队选拔赛四川
a180285幸运地被选做了地球到喵星球的留学生。他发现喵星人在上课前的点名现象非常有趣。
假设课堂上有 N 个喵星人,每个喵星人的名字由姓和名构成。喵星球上的老师会选择M 个串来点名,每次读出一个串的时候,如果这个串是一个喵星人的姓或名的子串,那么这个喵星人就必须答到。
然而,由于喵星人的字码过于古怪,以至于不能用 ASCII 码来表示。为了方便描述,a180285决定用数串来表示喵星人的名字。
现在你能帮助 a180285 统计每次点名的时候有多少喵星人答到,以及 M 次点名结束后每个喵星人答到多少次吗?
现在定义喵星球上的字符串给定方法:
先给出一个正整数 L,表示字符串的长度,接下来L个整数表示字符串的每个字符。
输入的第一行是两个整数N和M。
接下来有N行,每行包含第 i个喵星人的姓和名两个串。姓和名都是标准的喵星球上的字符串。
接下来有M行,每行包含一个喵星球上的字符串,表示老师点名的串。
对于每个老师点名的串输出有多少个喵星人应该答到。
然后在最后一行输出每个喵星人被点到多少次。
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
2
1
0
1 2
对于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喵星球上的点名的更多相关文章
- BZOJ 2754: [SCOI2012]喵星球上的点名
2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 649 Solved: 305[Submit][Sta ...
- BZOJ2754: [SCOI2012]喵星球上的点名
2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 680 Solved: 314[Submit][Sta ...
- BZOJ 2754: [SCOI2012]喵星球上的点名 [后缀数组+暴力]
2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 1906 Solved: 839[Submit][St ...
- BZOJ 2754: [SCOI2012]喵星球上的点名 [AC自动机+map+暴力]
2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 1902 Solved: 837[Submit][St ...
- P2336 [SCOI2012]喵星球上的点名(后缀自动机+莫队+dfs序)
P2336 [SCOI2012]喵星球上的点名 名字怎么存?显然是后缀自动机辣 询问点到多少个喵喵喵其实就是 查询后缀自动机上parent树的一个子树 于是我们考虑莫队 怎么树上莫队呢 我们用dfs序 ...
- 洛咕 P2336 [SCOI2012]喵星球上的点名
洛咕 P2336 [SCOI2012]喵星球上的点名 先求出SA和height,一个点名串对应的就是一段区间,还有很多个点,就转化成了 有很多个区间,很多个点集,对每个区间计算和多少个点集有交,对每个 ...
- 洛谷 P2336 [SCOI2012]喵星球上的点名 解题报告
P2336 [SCOI2012]喵星球上的点名 题目描述 a180285 幸运地被选做了地球到喵星球的留学生.他发现喵星人在上课前的点名现象非常有趣. 假设课堂上有 \(N\) 个喵星人,每个喵星人的 ...
- 【BZOJ2754】[SCOI2012]喵星球上的点名
[BZOJ2754][SCOI2012]喵星球上的点名 题面 bzoj 洛谷 题解 这题有各种神仙做法啊,什么暴力\(AC\)自动机.\(SAM\)等等五花八门 我这个蒟蒻在这里提供一种复杂度正确且常 ...
- 2754. [SCOI2012]喵星球上的点名【后缀数组】
Description a180285幸运地被选做了地球到喵星球的留学生.他发现喵星人在上课前的点名现象非常有趣. 假设课堂上有N个喵星人,每个喵星人的名字由姓和名构成.喵星球上的老师会选择M个串 ...
随机推荐
- Software-Defined Networking A Comprehensive Survey(一)
传统网络:1 复杂,难于管理 2 很难实现根据之前定义的方案进行配置,3 对于缺陷.变化不能够再次进行配置 4 控制和数据平面绑定在一起,使许多缺陷难于解决 SDN网络:通过打破传统网络垂直整合,从底 ...
- Leetcode题库——11.盛最多水的容器
@author: ZZQ @software: PyCharm @file: maxArea.py @time: 2018/10/11 21:47 说明:给定 n 个非负整数 a1,a2,...,an ...
- 团队作业5-Alpha版本测试报告(彼岸芳华队)
请根据团队项目中软件的需求文档.功能说明.系统设计和测试计划,写出软件的测试过程和测试结果,并回答下述问题. 一.在测试过程中总共发现了多少Bug?每个类别的Bug分别为多少个?(10分) 在测试过程 ...
- HTTP&HTTPS、GET&POST
1.HTTP&HTTPS: HTTP协议传输的数据都是未加密的,也就是明文的,因此使用HTTP协议传输隐私信息非常不安全,为了保证这些隐私数据能加密传输,于是网景公司设计了SSL(Secure ...
- Sprint Boot入门(1):创建第一个Spring Boot应用
搭建工程 注:建议使用eclipse的STS插件创建Spring项目,而不是下面的Gradle项目,否则会导致有一些Spring文件不存在. new Gradle Project,如下 点next,如 ...
- Keil C51 的printf
转自:http://blog.csdn.net/zhanglianpin/article/details/44779009 在Keil C51 中使用printf ,首先需要重新实现 putchar( ...
- C++派生类构造函数调用顺序(详解)
我们来看下面一段代码: class B1 { public: B1(int i) {cout<<"constructing B1 "<<i<<e ...
- jquery 取消全选和全选功能 不全选
代码如下 function ckSelectAll() { if ($('#ckSelectAll').is(':checked') == true) { $("INPUT[name='ch ...
- PAT 甲级 1155 Heap Paths
https://pintia.cn/problem-sets/994805342720868352/problems/1071785408849047552 In computer science, ...
- angular入门学习文档之一
一.数据双向绑定 angular(下面统一简称ng)强大的地方莫过于它内置的数据双向绑定功能,下面我们通过一个简单的例子来演示ng强大的双向绑定数据的能力. 代码如下: 1.dom结构: 1.< ...