AC自动机-HDU2222-模板题

http://acm.hdu.edu.cn/showproblem.php?pid=2222

一个AC自动机的模板题。用的kuangbin的模板,静态建Trie树。可能遇到MLE的情况要转动态建树。

 

AC自动机的讲解看这里

http://blog.csdn.net/niushuai666/article/details/7002823

http://blog.csdn.net/mobius_strip/article/details/22549517

/*--------------------------------------------------------------------------------------*/
//        Helica's header 
//        Second Editions
//        2015.11.7
//
#include <algorithm>
#include <iostream>
#include <cstring>
#include <ctype.h>
#include <cstdlib>
#include <cstdio>
#include <vector>
#include <string>
#include <queue>
#include <stack>
#include <cmath>
#include <set>
#include <map>//debug function for a N*M array 
#define debug_map(N,M,G) printf("\n");for(int i=0;i<(N);i++)\
{for(int j=0;j<(M);j++){\
printf("%d",G[i][j]);}printf("\n");}                
//debug function for int,float,double,etc.
#define debug_var(X) cout<<#X"="<<X<<endl;
/*--------------------------------------------------------------------------------------*/
using namespace std;int N,M,T;struct Trie
{int next[500010][26],fail[500010],end[500010];int root,L;int newnode(){for(int i=0;i<26;i++) next[L][i] = -1;end[L++] = 0;return L-1;}void init(){L = 0;root = newnode();}void insert(char *s){int len = strlen(s);int now = root;for(int i=0;i<len;i++){if(next[now][s[i]-'a'] == -1)next[now][s[i]-'a'] = newnode();now = next[now][s[i]-'a'];}end[now]++;}void build(){queue <int> Q;fail[root] = root;for(int i=0;i<26;i++)if(next[root][i] == -1)next[root][i] = root;else{fail[next[root][i]] = root;Q.push(next[root][i]);}while(!Q.empty()){int now = Q.front();Q.pop();for(int i=0;i<26;i++){if(next[now][i] == -1)next[now][i] = next[fail[now]][i];else{fail[next[now][i]] = next[fail[now]][i];Q.push(next[now][i]);}}}}int query(char *s){int len = strlen(s);int now = root;int ans = 0;for(int i=0;i<len;i++){now = next[now][s[i]-'a'];int temp = now;while(temp != root){ans += end[temp];end[temp] = 0;temp = fail[temp];}}return ans;}void debug(){for(int i=0;i<L;i++){printf("id = %3d,fail = %3d,end = %3d,chi = [",i,fail[i],end[i]);for(int j=0;j<26;j++)printf("%2d",next[i][j]);printf("]\n");}}
};char buf[1000100];
Trie ac;int main()
{scanf("%d",&T);while(T--){ac.init();scanf("%d",&N);for(int i=0;i<N;i++){scanf("%s",buf);ac.insert(buf);}ac.build();//ac.debug();scanf("%s",buf);printf("%d\n",ac.query(buf));}
}

 

 

第N次入门AC自动机。。。成功。。。

转载于:https://www.cnblogs.com/helica/p/5037814.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/404558.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2012网页设计趋势(下)

CSS3 技术 不确定你可以利用CSS3吗&#xff1f;再想想。网络先锋如Andy Clarke 和 Jeremy Keith一直提倡网页设计要“逐步加强”。逐步增强是指在网站设计师时要兼顾到旧版浏览器的可用性&#xff0c;而“增强”则是针对喜欢最新技术的用户。在这样的设计阵营&#xff0c;你利用…

树莓派CM4 装系统和换源

一、系统下载 官网&#xff1a;Operating system images – Raspberry Pi 最新的版本删除了默认账号pi。考虑以前的使用习惯&#xff0c;此处下载以前的buster debian版本。CM4是arm64架构&#xff0c;根据板子的配置容量不同可选相应的版本&#xff0c;我这里选择lite版本。…

关于 not enough actual parameters for macro ...

From: http://blog.csdn.net/liyelun/article/details/5416253 今天修改工程&#xff0c;为了提高编译速度&#xff0c;将#inclue<dshow.h>放到了stdafx.h中&#xff0c;然后重新编译工程。结果有两个文件编译没通过&#xff0c;并且导致的编译错误近百个。 觉得奇怪&…

[react] 有用过react的Fragment吗?它的运用场景是什么

[react] 有用过react的Fragment吗&#xff1f;它的运用场景是什么 代替div作为外层&#xff0c;可做不可见的包裹元素。 个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端…

宝贝女儿半岁啦

亲爱的赵曦涵宝宝&#xff0c;祝贺你今天已经整整半岁了(如今28日00时不到10分) &#xff01;不知道你什么时候才可以看懂老妈写给你的这第一封信&#xff0c;或许要3年&#xff0c;5年&#xff0c;或者更久吧。今天是你姥爷的54周岁生日&#xff0c;我定了蛋糕&#xff0c;给你…

sharedPreferences的用法

做软件开发应该都知道&#xff0c;很多软件会有配置文件&#xff0c;里面存放这程序运行当中的各个属性值&#xff0c;由于其配置信息并不多&#xff0c;如果采用数据库来存放并不划算&#xff0c;因为数据库连 接跟操作等耗时大大影响了程序的效率&#xff0c;因此我们使用键值…

VC6中使用内存DC加载并显示JPG图片的注意事项

From: http://blog.csdn.net/boythl/article/details/3137446 今天在VC6中显示JPG图片&#xff0c;采用了内存DC缓存的方法刷新&#xff0c;但死活刷不出来&#xff0c;查了一下午才明白&#xff08;没办法&#xff0c;很少用GDI&#xff0c;我小菜一个:( &#xff09;&…

C++沉思录

C沉思录 第五章 代理类 : 为了实现容器或数组的多态性。 1 #include <iostream> 2 3 using namespace std; 4 5 class Vehicle 6 { 7 public: 8 virtual void start() const 0 ; 9 virtual Vehicle* copy() const 0 ;10 virtual ~Vehicle() {};11 };12 1…

VC内存泄露检查工具:VisualLeakDetector

From: http://www.xdowns.com/article/170/Article_3060.html 初识Visual Leak Detector 灵活自由是C/C语言的一大特色&#xff0c;而这也为C/C程序员出了一个难题。当程序越来越复杂时&#xff0c;内存的管理也会变得越加复杂&#xff0c;稍有不慎就会出现内存问题。内…

JQuery Easy Ui 可装载组合框 - ComboBox

JQuery Easy Ui 可装载组合框 - ComboBox 可装载组合框 - ComboBox 继承自$.fn.combo.defaults,通过$.fn.combobox.defaults覆盖默认值 combobox显示的是一个可以编辑的文本框和一个下拉列表.允许用户从里面选择一个或者是多个值,用户可以直接输入值到列表顶部,或者可以从列表选…

提高 Web 站点性能的最佳实践

原文地址&#xff1a;http://developer.yahoo.com/performance/rules.html 本文在尊重原文基础上&#xff0c;尽量翻译得通俗易懂一些。 本文内容 提高 Web 站点性能的最佳实践最大限度减少 HTTP 请求 使用内容分发网络&#xff08;CDN&#xff09; 添加 Expires 或 Cache – C…

内存泄露检测工具比较

From: http://blog.163.com/zhuang_qianxin/blog/static/29765138201051092529107/ 1. ccmalloc&#xff0d;Linux和Solaris下对C和C程序的简单的使用内存泄漏和malloc调试库。 2. Dmalloc&#xff0d;Debug Malloc Library. 3. Electric Fence&#xff0…

用SQL实现统计报表中的“小计”和“合计”

客户提出需求&#xff0c;针对某一列分组加上小计&#xff0c;合计汇总。网上找了一些有关SQL加合计的语句。都不是很理想。决定自己动手写。 思路有三个&#xff1a; 1.很多用GROUPPING和ROLLUP来实现。 优点实现代码简洁&#xff0c;要求对GROUPPING和ROLLUP很深的理解。 …

Linux时间函数

From: http://blog.csdn.net/water_cow/article/details/7521567 系统环境&#xff1a;ubuntu10.04简介本文旨在为了解Linux各种时间类型与时间函数提供技术文档。1、Linux下常用时间类型Linux下常用时间类型有四种&#xff1a;time_t、struct tm、struct timeval、struct ti…

Ubuntu安装BackExec Remote Agent for Linux

把那个RALUS_RMALS_RAMS-4164.5.tar.gz的安装包传输至服务器安装&#xff0c;注意一点&#xff0c;需要新建个目录&#xff0c;把该文件放进去&#xff0c;否则&#xff0c;该文件直接解压的话&#xff0c;将在该目录生成一大堆文件。&#xff08;symantec怎么会这么制作安装包…

Linux C函数之时间函数

From: http://school.cfan.com.cn/system/unix/2009-07-01/1246421513d214853.shtml 时间函数(13) 函数分类: 1. 设置时间: settimeofday, tzset 2. 获取时间: time, ftime, gettimeofday 3. 时间格式转换: mktime, strftime; gmtime, localtime; asctime, ctime 4. 其他: cl…

Linux串口驱动程序-termios结构体中的VTIME和VMIN应用

#Linux串口驱动程序-termios结构体中的VTIME和VMIN应用 参考 https://tldp.org/HOWTO/Serial-Programming-HOWTO/x115.html 最近在看Unix-linux系统编程一书&#xff0c;做到第六章的时候需要做一个标准输入的超时处理。如下图所示 需要改动的&#xff0c;是原书的play_aga…

C# 线程手册 第一章 线程定义 .NET 和 C# 对线程的支持

由于.NET Framework 支持自由线程&#xff0c;所以自由线程在所有.NET 语言中都存在&#xff0c;包括C#和VB.NET. 在下一部分&#xff0c;我们将着重关注如何提供这种支持以及更多关于线程是如何做到的&#xff0c;而不再关注线程是什么。我们将讨论一些能够进一步帮助区分进程…

SAFEARRAY使用实例

From: http://blog.csdn.net/csfreebird/article/details/234547 目录&#xff1a;SAFEARRAY使用实例目录&#xff1a;前言&#xff1a;何谓SAFEARRAY&#xff1a;创建SAFEARRAY:方法一&#xff1a;使用SafeArrayAllocDescriptor在栈上创建一维数组方法二&#xff1a;使用Safe…

前端第一天 HTML基础

前端第一天 HTML基础 1.是什么 HTML里值得记住的就几个点&#xff0c;第一&#xff0c;这东西还有自身也有结构 这东西是个超文本&#xff0c;可以挂载文字图片视频或者别的超文本自身可以通过各种各样的tag进行标记&#xff0c;排版给浏览器提供渲染的依据&#xff0c; 2.…