bzoj千题计划315:bzoj3172: [Tjoi2013]单词(AC自动机)

时间:2023-02-03 23:23:13

https://www.lydsy.com/JudgeOnline/problem.php?id=3172

构建AC自动机

在fail树上,点i的子树大小 表示trie树上根节点到i构成的单词 是 多少个(子)串的子串

#include<queue>
#include<cstdio>
#include<cstring> using namespace std; #define N 2000001 using namespace std; int pos[]; int tr[N][],id=;
int f[N],ans[N]; char s[]; queue<int>q; int d[N],cnt; void insert(int &pos)
{
int now=,len=strlen(s);
int x;
for(int i=;i<len;++i)
{
x=s[i]-'a';
if(!tr[now][x]) tr[now][x]=++id;
now=tr[now][x];
ans[now]++;
}
pos=now;
} void get_fail()
{
for(int i=;i<;++i) tr[][i]=;
q.push();
int now,j;
while(!q.empty())
{
now=q.front();
d[++cnt]=now;
q.pop();
for(int i=;i<;++i)
if(!tr[now][i]) tr[now][i]=tr[f[now]][i];
else
{
q.push(tr[now][i]);
j=f[now];
f[tr[now][i]]=tr[j][i];
}
}
} int main()
{
int n;
scanf("%d",&n);
for(int i=;i<=n;++i)
{
scanf("%s",s);
insert(pos[i]);
}
get_fail();
for(int i=cnt;i;--i) ans[f[d[i]]]+=ans[d[i]];
for(int i=;i<=n;++i) printf("%d\n",ans[pos[i]]);
}

bzoj千题计划315:bzoj3172: [Tjoi2013]单词(AC自动机)的更多相关文章

  1. BZOJ3172&lbrack;Tjoi2013&rsqb;单词——AC自动机&lpar;fail树&rpar;

    题目描述 某人读论文,一篇论文是由许多单词组成.但他发现一个单词会在论文中出现很多次,现在想知道每个单词分别在论文中出现多少次. 输入 第一个一个整数N,表示有多少个单词,接下来N行每行一个单词.每个 ...

  2. bzoj3172&colon; &lbrack;Tjoi2013&rsqb;单词 ac自动机

    某人读论文,一篇论文是由许多单词组成.但他发现一个单词会在论文中出现很多次,现在想知道每个单词分别在论文中出现多少次. Input 第一个一个整数N,表示有多少个单词,接下来N行每行一个单词.每个单词 ...

  3. bzoj千题计划300:bzoj4823&colon; &lbrack;Cqoi2017&rsqb;老C的方块

    http://www.lydsy.com/JudgeOnline/problem.php?id=4823 讨厌的形状就是四联通图 且左右各连一个方块 那么破坏所有满足条件的四联通就好了 按上图方式染色 ...

  4. 【BZOJ3172】&lbrack;Tjoi2013&rsqb;单词 AC自动机

    [BZOJ3172][Tjoi2013]单词 Description 某人读论文,一篇论文是由许多单词组成.但他发现一个单词会在论文中出现很多次,现在想知道每个单词分别在论文中出现多少次. Input ...

  5. BZOJ 3172&colon; &lbrack;Tjoi2013&rsqb;单词 &lbrack;AC自动机 Fail树&rsqb;

    3172: [Tjoi2013]单词 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 3198  Solved: 1532[Submit][Status ...

  6. bzoj 3172&colon; &lbrack;Tjoi2013&rsqb;单词 AC自动机

    3172: [Tjoi2013]单词 Time Limit: 20 Sec  Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...

  7. 【BZOJ-3172】单词 AC自动机

    3172: [Tjoi2013]单词 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 2567  Solved: 1200[Submit][Status ...

  8. &lbrack;TJOI2013&rsqb;单词 AC自动机

    题面: 洛谷 题解: 很久之前做的题了,只不过之前一直90....最近才发现是哪里写错了. 我们对字符集建AC自动机. 首先考虑一个暴力的做法,把文章当做一个长串,直接在自动机上跳,但是我们会发现,这 ...

  9. &lbrack;TJOI2013&rsqb;单词 AC 自动机

    题目描述: 小张最近在忙毕设,所以一直在读论文. 一篇论文是由许多单词组成但小张发现一个单词会在论文中出现很多次,他想知道每个单词分别在论文中出现了多少次. 题解: AC 自动机裸题,将所有字符串读入 ...

随机推荐

  1. Git忽略&period;gitignore规则不生效的解决办法

    在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改根目录中 .gitignore 文件的方法(如无,则需自己手工建立此文件). 这个文件每一行保存了一个匹配的规则例如: # 此为 ...

  2. &lbrack;经典php视频&rsqb;构建正则表达式解析网页中的图像标记&lt&semi;img&gt&semi;

    这是高洛峰php视频中的一段,视频中一边分析需要的功能,一边构建greg_match函数的参数,边讲解边实战,是非常好的一种构建功能的演示. 你不可能把浩瀚的IT资料都记在脑袋里,也不可能随时随地透过 ...

  3. java读取照片信息 获取照片拍摄时的经纬度

    项目结构 源码:ImageInfo.zip 第一步:添加需要的架包metadate-extractor.jar 架包下载地址:https://code.google.com/p/metadata-ex ...

  4. Android执行shell命令

    一.方法 /** * 执行一个shell命令,并返回字符串值 * * @param cmd * 命令名称&参数组成的数组(例如:{"/system/bin/cat", &q ...

  5. 用Ghostscript API将PDF格式转换为图像格式&lpar;C&num;&rpar;

    原文:用Ghostscript API将PDF格式转换为图像格式(C#) 由于项目需要在.net下将pdf转换为普通图像格式,在网上搜了好久终于找到一个解决方案,于是采用拿来主义直接用.来源见代码中注 ...

  6. easyUI分页实现加搜索功能

    前台页面: js代码: ps:pagination为true时会在table下面加上easyUI的分页. load函数会将查询值传给datagrid并传给后台重新加载. DAO.xml为: 后台代码实 ...

  7. 微信小程序开发平台新功能「云开发」快速上手体验

    微信小程序开发平台刚刚开放了一个全新的功能:云开发. 简单地说就是将开发人员搭建微信小程序后端的成本再次降低,此文刚好在此产品公测时,来快速上手看看都有哪些方便开发者的功能更新. 微信小程序一直保持一 ...

  8. php的pid文件指定用户

    比如pid文件指定www用户,首先得有这用户和用户组. 找到pathtophp-fpm.conf文件,修改里面得相关内容. 修改listen.owner=www listen.group=www us ...

  9. Orchard Core 版本冲突 The type &&num;39&semi;FormTagHelper&&num;39&semi; exists in both &&num;39&semi;Microsoft&period;AspNetCore&period;Mvc&period;TagHelpers&comma; Version&equals;2&period;1&period;1&period;0&comma; Culture&equals;neutral&comma; PublicKeyToken&equals;adb9793829ddae60&&num;39&semi; and&period;&period;&period;

    最近老大让我看Orchard Core,这是一个CMS系统.可以先参考大佬的文章:https://www.cnblogs.com/shanyou/archive/2018/09/25/9700422. ...

  10. 【Shell】Linux的判断表达式:-d&comma;-f&comma;-e等

    文件比较运算符 表达式         说明                            案例 -e filename    如果filename存在,则为真        [ –e /et ...