【AC自动机】HDU2222Keywords Search

原创 2015年11月10日 21:55:29

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2222

这个题目刚开始还不会,但是轮到了我给我同学讲课,之前就有看过,一直都没懂。就唯一的知道要会AC自动机,就得先会KMP和字典树。于是我就在杭电上挂了这题,默默的刷着KMP和字典树。突然要我讲课,没办法,就赶紧赶紧的临时在认真的看,分析,最后赶鸭子上架,懵懵懂懂的就上去讲了。讲着讲着发现这个模板我就这样理解了。。。哈哈,真的让我明白,你能做题,不一定能讲清楚一道题,当你能讲清楚一道题,说明你弄懂了这道题。嘿嘿。。。

我是看到这两个博客,学过来的,代码也是综合了一下。

链接:http://www.cppblog.com/mythit/archive/2009/04/21/80633.html

          http://blog.csdn.net/hnust_xiehonghao/article/details/9130539

#include<iostream>
#include<string>
#include<cstring>
#include<cstdio>
#include<queue>
using namespace std;
const int N=26;
char str[1000005];
char s[55];
struct node{
    node *fail;
    node *next[N];
    int cnt;
    node(){
        fail=NULL;
        cnt=0;
        memset(next,0,sizeof(next));
    }
};
node *p,*temp,*head;
void Insert(char s[])           //  建立字典树;
{
    p=head;
    int i=0,id;
    while(s[i]){
        id=s[i++]-'a';
        if(p->next[id]==NULL) p->next[id]=new node();
        p=p->next[id];
    }
    p->cnt++;
}
void get_fail()             //  BFS构造fail指针;
{
    node *son;              //  保存子节点;
    p=head;
    queue<struct node *>q;          //  用队列BFS;
    q.push(p);
    while(!q.empty()){
        temp=q.front();
        q.pop();
        for(int i=0;i<26;i++){
            son=temp->next[i];
            if(son!=NULL){                      //  子节点不为空,说明存在该字母;
                if(temp==head) son->fail=head;  //  如果子节点的父节点为head,那么fail指针指向head;
                else{
                    p=temp->fail;               //  p等于当前son的父节点的fail指针;
                    while(p){
                        if(p->next[i]){         //  如果存在该字母,说明p->next[i]链前面出现的字母也与之匹配;
                            son->fail=p->next[i];
                            break;
                        }
                        p=p->fail;
                    }
                    if(!p) son->fail=head;
                }
                q.push(son);
            }
        }
    }
}
int Query()     //  遍历;
{
    int i=0,ans=0;
    p=head;
    while(str[i]){
        int id=str[i++]-'a';
        while( p->next[id]==NULL && p!=head) p=p->fail;     //  当p的子节点不存在,且p不是head的节点时,(因为这种情况当前位置p后面是不会有匹配的字母了)p=p->fail;
        p=p->next[id];
        if(!p) p=head;          //  如果p为NULL,那么说明该字母开头的单词匹配失败了;
        temp=p;
        while(temp!=head && temp->cnt!=-1){     //  当temp存在时,且没有被计算过时,进入while循环;
            ans+=temp->cnt;
            temp->cnt=-1;
            temp=temp->fail;        //  访问下一个匹配位置;
        }
    }
    return ans;
}
int main()
{
    int t,n;
    scanf("%d",&t);
    while(t--){
        head=new node();
        scanf("%d",&n);
        getchar();
        while(n--){
            gets(s);
            Insert(s);
        }
        get_fail();
        scanf("%s",str);
        printf("%d\n",Query());
    }
    return 0;
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

HDU 2222 Keywords Search(AC自动机)

请不要随便指点别人该怎么做、每个人的人生都应该自己掌握、你给不了别人一切、你也不懂别人的忧伤、                             &...

HDU2222-Keywords Search AC自动机

HDU2222-Keywords Search AC自动机算法

AC自动机模板——HDU2222 Keywords Search

Keywords Search Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Oth...

HDU 2222 Keywords Search (AC自动机入门题)

题意: 题解: //先调用PreProcess()初始化 //Insert()添加串 Find()查找串 //get(char s) 返回字符s所对应的编号(考虑字符集合可能是’A’-’Z’或者...
  • Tsaid
  • Tsaid
  • 2012-10-10 23:13
  • 447

HDU - 2222 Keywords Search AC自动机

题意:给出n个字符串为这些字符串在主串s中出现的个数。 AC自动机 裸的AC自动机,注意下给定模式串可能有一些相同的串,然后按照主串在自动机上遍历即可。 复杂度 O(n)

hdu 2222 Keywords Search (ac自动机)

题目:http://acm.hdu.edu.cn/showproblem.php?pid=2222 题意:求有多少个模式串出现在文本串里面。 分析:ac自动机模版题。说一下自己对ac自动机的理解,①f...

【HDU2222】【AC自动机模板 测烂为止】Keywords Search

传送门:HDU222 描述: Keywords Search Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/1310...

HDU2222 Keywords Search [AC自动机]

Keywords Search Time Limit: 1000MS Memory Limit: 131072KB 64bit IO Format: %I64d & %I64uDescripti...

HDU2222 Keywords Search AC自动机

题意:给定n个模式串和一个文本串,问有多少模式串出现在文本中。思路:AC自动机模板题。原谅我也是初学,可能也无法讲清楚AC自动机的思想。大家可以去参考大牛们博客的讲解,并附上AC自动机讲解视频AC自动...

Keywords Search hdu2222 ac自动机

Description给定T组数据n个单词一个字符串s求s中有多少给出的单词出现Solution无力吐槽题号ac自动机裸题模板,学习了 所谓ac自动机就是一棵带fail指针的trie,t(i)的fa...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)