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个串 ...
随机推荐
- HDU 4281 Judges' response 状压dp+多旅行商问题
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4281 Judges' response Time Limit: 2000/1000 MS (Java ...
- grunt入门讲解4:如何创建task(任务)
每当运行Grunt时, 你可以为其指定一个或多个任务, 这些任务用于告诉Grunt你想要它做什么事情. 如果你没有指定一个任务,并且你已经定义一个名为 "default" 的任务, ...
- 二叉查找树ADT--C语言描述
首先给出此ADT的声明: struct TreeNode; typedef struct TreeNode *Position; typedef struct TreeNode *SearchTree ...
- Selenium_RC环境配置
上一篇里,对Selenium IDE自动录制的脚本进行了一下分析,按照前两篇的操作,很明显,新建的 那个Test.py文件是不能运行的.关键问题在于1.没有装Python:2.没有装Selenium_ ...
- By.cssSelector定位元素一个不足发现
这个如果用cssSelector定位,代码如下,此时输出的数值是0 System.out.println(driver.findElements(By.cssSelector("div[c ...
- [转帖]高通推出八核笔电处理器骁龙8cx 能超英特尔吗?
高通推出八核笔电处理器骁龙8cx 能超英特尔吗? https://baijiahao.baidu.com/s?id=1619154699684981202&wfr=spider&for ...
- [转帖]AMD、英特尔为何争相走向胶水多核处理器?真相在此
AMD.英特尔为何争相走向胶水多核处理器?真相在此 胶水多核到底好不好?这个事不是简单一句话能说明的,今天的超能课堂里我们就来聊聊MCM胶水多核技术的过去及未来. 作者:孟宪瑞来源:超能网|2018- ...
- 微信 小程序布局 scroll-view
//滚动触底事件 <scroll-view scroll-y lower-threshold="0" bindscrolltolower="scrollBott ...
- Java:JUnit4使用详解
对于Junit的总是一知半解不太懂,现在认真梳理一下: 此次针对的是Junit4版本,注解也是在Junit4版本才有的,之前的版本并无注解功能.而注解开发基本上被认为是一种优秀的设计,所以我们写单元测 ...
- lepus天兔数据库监控
本篇文章的前提是服务器装了mysql服务.git,我这边就不写出来了,自行百度,装下mysql服务,比较简单 一.安装LAMP基础环境 Xampp下载地址:https://www.apachefrie ...