Aho-Corasick automaton 模板

typedef struct Node* node;const int MAXNs = ;//模式串最大長度 
const int MAXNS = ;//文章(待匹配串)最大長度 struct Node{node next[26];node fail;//失配指针int sum;Node(){sum = 0;fail = NULL;memset(next,NULL,sizeof next);}
};char s[MAXNs];//模式串void Insert(node root)//字典树的建立
{node p = root;int len = strlen(s);for(int i=0 ; i<len ; ++i){int x = s[i] - 'a';if(p->next[x] == NULL){node newnode = new Node();p->next[x] = newnode;}p = p->next[x];}p->sum++;
}void build_fail_pointer(node root)//构造fail指针
{queue<node> Q;Q.push(root);node p,temp;while(!Q.empty()){temp = Q.front();Q.pop();for(int i=0 ; i<26 ; ++i){if(temp->next[i]){if(temp == root){temp->next[i]->fail = root;}else{p = temp->fail;while(p){if(p->next[i]){temp->next[i]->fail = p->next[i];break;}p = p->fail;}if(p == NULL) temp->next[i]->fail = root;}Q.push(temp->next[i]);}}}
}char S[MAXNS];//文章(待匹配串)int ac_automation(node root)//利用fail指针进行匹配。
{node p = root;int len = strlen(S);int ans = 0;for(int i=0 ; i<len ; ++i){int x = S[i] - 'a';while(!p->next[x] && p != root) p = p->fail;p = p->next[x];if(!p) p = root;node temp = p;while(temp != root){if(temp->sum >= 0){ans += temp->sum;temp->sum = -1;}else break;temp = temp->fail;}}return ans;
}void Del(node root){for(int i=0 ; i<26 ; ++i){if(root->next[i])Del(root->next[i]);}delete(root);
}int main(){int T;// case數量 scanf("%d",&T);while(T--){int N;//模式串數量 node root = new Node();scanf("%d",&N);while(N--){scanf("%s",s);Insert(root);}scanf("%s",S);build_fail_pointer(root);//构造fail指针printf("%d\n",ac_automation(root));Del(root);}return 0;
}

 

转载于:https://www.cnblogs.com/vocaloid01/p/9514016.html

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

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

相关文章

Ubuntu Server 14.04 下root无法ssh登陆

今天安装了Ubuntu Server 14.04 在终端配置了root密码后&#xff0c;使用SecureCRT和putty竟然不能ssh登陆&#xff0c;SecureCRT一直提示密码不对&#xff0c;但是可以肯定输入的密码100%正确&#xff0c;用putty则一直报Access Denied&#xff0c;所以可以肯定系统限制了ro…

计算机的控制面板打不开,控制面板打不开,教您控制面板打不开怎么办

最近有些不少的小伙伴向小编反映说&#xff0c;控制面板突然出现了打不开的情况&#xff0c;那么遇到这种情况该怎么办呢&#xff1f;其实控制面板打不开很有可能是因为系统文件损坏造成的。今天&#xff0c;小编就来把打不开控制面板的解决方法分享给你们。其实控制面板是我们…

【算法题】Multiples of 3 and 5

Multiples of 3 and 5 原题 题意如下&#xff1a; 找出N以内的3和5的倍数的和。 思路 1、刚看到觉得好弱智&#xff0c;直接遍历一遍不就OK了吗&#xff1f;但是第2和第3个测试用例报了TLE&#xff0c;超时。 2、然后想不出来了&#xff0c;搜了一下&#xff0c;发现有一个类似…

PIL简单图片处理(上)

自己看了下python&#xff0c;本来想照教程上一点一点学的&#xff0c;学了一会发现好没劲&#xff08;教程本身质量很好&#xff09;&#xff0c;学python就是为了好玩&#xff0c;为什么还这么按部就班勒&#xff1f;果断google下python的爬虫&#xff08;开始目的是这个&…

方舟服务器制作修改,ARK方舟:生存进化服务器禁止物品制造的修改方法

ARK方舟:生存进化服务器禁止物品制造的修改方法代码对应的文件目录:文件:Game.ini框架:[/script/shootergame.shootergamemode]例如禁用C4遥控器代码为:ConfigOverrideItemCraftingCosts(ItemClassString"PrimalItem_WeaponC4_C",BaseCraftingResourceRequirements((…

Java中ArrayList的使用

ArrayList类是一个特殊的数组--动态数组。来自于System.Collections命名空间&#xff1b;通过添加和删除元素&#xff0c;就可以动态改变数组的长度。 优点&#xff1a; 1、支持自动改变大小 2、可以灵活的插入元素 3、可以灵活的删除元素 局限&#xff1a; 比一般的数组的速度…

mallco动态分配_malloc动态分配的内存的生存周期是多少?

曾经有一个朋友提过这样一个问题&#xff0c;malloc动态分配的内存的生存周期是多少当时直接回答&#xff0c;当然是在调用free进行释放之前阿!!但回头我仔细想过这个问题&#xff0c;在free调用之前那段范围内&#xff0c;但free只有一个指针参数&#xff0c;它是如何知道要释…

中兴中心管理服务器fxh3120,中兴多媒体业务中心ZXMS80

运营支撑层&#xff1a; 提供面向视讯用户的客服中心和面向管理员的业务中心、网管中心。客服中心提供会议预约、会议控制、帐单查询、意见反馈等功能。业务中心分为业务受理中心、业务管理中心、认证计费中心。其中业务受理中心实现开户、放号及收费等功能&#xff1b;业务管理…

随机森林经典文

原文链接 转载于:https://www.cnblogs.com/luoganttcc/p/10525324.html

python namespace unique_Python使用uuid库生成唯一标识ID

uuid是128位的全局唯一标识符(univeral unique identifier)&#xff0c;通常用32位的一个字符串的形式来表现。有时也称guid(globalunique identifier)。python中自带了uuid模块来进行uuid的生成和管理工作。python中的uuid模块基于信息如MAC地址、时间戳、命名空间、随机数、伪…

SQL Server 2008空间数据应用系列四:基础空间对象与函数应用

SQL Server 2008空间数据应用系列四&#xff1a;基础空间对象与函数应用 原文:SQL Server 2008空间数据应用系列四&#xff1a;基础空间对象与函数应用友情提示&#xff0c;您阅读本篇博文的先决条件如下&#xff1a; 1、本文示例基于Microsoft SQL Server 2008 R2调测。 2、具…

HBase-1.2.4LruBlockCache实现分析(一)

一、简介 BlockCache是HBase中的一个重要特性&#xff0c;相比于写数据时缓存为Memstore&#xff0c;读数据时的缓存则为BlockCache。 LruBlockCache是HBase中BlockCache的默认实现&#xff0c;它采用严格的LRU算法来淘汰Block。 二、缓存级别 目前有三种缓存级别&#xf…

c .net ajax,Asp.net mvc 2中使用Ajax的三种方式

在Asp.net MVC中&#xff0c;我们能非常方便的使用Ajax。这篇文章将介绍三种Ajax使用的方式&#xff0c;分别为原始的Ajax调用、Jquery、Ajax Helper。分别采用这三种方式结合asp.net mvc去实现一个史上最简单的留言板。首先看一下原始的Ajax的调用的:定义CommentController&am…

爆款AR游戏如何打造?网易杨鹏以《悠梦》为例详解前沿技术

本文来自网易云社区。 7月31日&#xff0c;2018云创大会游戏论坛在杭州国际博览中心103B圆满举行。本场游戏论坛聚焦探讨了可能对游戏行业发展有重大推动的新技术、新实践&#xff0c;如AR、区块链、安全、大数据等。 网易AR游戏生态合作负责人杨鹏表示&#xff0c;传统游戏模式…

景深决定照相机什么特性_照相机光圈与景深的关系

展开全部「光圈」&#xff0c;光圈是一个用来控制光线透过镜头&#xff0c;进入机身636f70793231313335323631343130323136353331333264663664内感光面的光量的装置&#xff0c;它通常是在镜头内。表达光圈大小我们是用f值。光圈f值镜头的焦距/镜头口径的直径从以上的公式可知要…

润乾V4导出TXT时自定义分隔符

&#xfeff;&#xfeff;◆ 背景说明 报表中&#xff0c;导出text时&#xff0c;默认没有分隔符&#xff1b;应用中对导出Text&#xff0c;希望能自定义分隔符。在tag中定义了 textDataSeparator属性&#xff0c;让用户在导出Text时自定义分隔符&#xff0c;从而确保满足应用…

Spark学习体会

在去年图计算工作中&#xff0c;和公司里实习的博士生尝试过Spark后&#xff0c;发现Spark比Hadoop在计算速度上后很大的提高。Spark的计算使用Scala语言编写代码&#xff0c;其中图计算用到了GraphX。对Spark技术的学习已经非常重要。 最近半年多时间里&#xff0c;经常看…

fastadmin自定义按钮不是ajax,Fastadmin 自定义按钮实现审核功能

功能描述新增自定义审核按钮&#xff0c;点击审核按钮后&#xff0c;按钮变为取消审核按钮&#xff0c;同理点击取消审核按钮后&#xff0c;按钮变为审核按钮实现功能如下图微信图片_20200827112914.png上代码{field: operate, title: __(Operate), table: table, events: Tabl…

函数的命名空间以及作用域

转载于:https://www.cnblogs.com/mpfei/p/9451208.html

python获取路由器数据包pppoe_PPPoE协议***4:如何得到PPPoE服务器的mac地址

在局域网中&#xff0c;怎样得到PPPoE服务器的mac地址是一件头疼的事情&#xff0c;特别是在windows环境下&#xff1b;得到PPPoE服务器mac地址的实现方法有两种&#xff1a;1.在windows下&#xff0c;我们运行wireshark软件&#xff0c;可以得到所有进出网卡的数据包格式和内容…