【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;
}


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

AC自动机的简单Java实现

AC自动机主要实现多模式字符匹配的快速查找,相关知识点为: 1.trie树 2.KMP算法 代码有相关注释,如下: import java.util.ArrayList; import jav...
  • sqh201030412
  • sqh201030412
  • 2017年01月05日 11:15
  • 1477

ac自动机最详细的讲解,让你一次学会ac自动机。

在没学ac自动机之前,觉得ac自动机是个很神奇,很高深,很难的算法,学完之后发现,ac自动机确实很神奇,很高深,但是却并不难。 我说ac自动机很神奇,在于这个算法中失配指针的妙处(好比kmp算法中的...
  • creatorx
  • creatorx
  • 2017年05月02日 19:51
  • 14539

Python算法实践——AC自动机

初来乍到CSDN,如果要说写博客的原因,想想平日学习编程语言看了那么多别人的博客,也该试着自己写一写了。第一次写博客写不知从何下笔,就从最近写的一个自动机开始吧。...
  • backkom_lory
  • backkom_lory
  • 2016年12月26日 23:01
  • 1178

AC自动机——HDU2222(题号很鬼畜)Keywords Search

http://acm.hdu.edu.cn/showproblem.php?pid=2222 这道题的算法就是我之前在trie中提到的高深算法——AC自动机!!! 千万不要以为AC自动机就是能使你...
  • jzq233jzq
  • jzq233jzq
  • 2017年03月16日 15:50
  • 276

HDU 2222 Keywords Search(AC自动机入门,模板)

Keywords Search Time Limit : 2000/1000ms (Java/Other) Memory Limit : 131072/131072K (Java/Othe...
  • lihao161530340
  • lihao161530340
  • 2017年11月26日 15:11
  • 114

hdu_2222_Keywords Search(AC自动机)

题型:AC自动机 题意:给出一系列模式串,问在主串中这些模式串总共出现了多少次。 分析:      看到题目就能想到的解决办法就是KMP,但是这是行不通的,因为有很多个模式串,一...
  • u010770930
  • u010770930
  • 2013年10月25日 18:02
  • 443

hdu2222 Keywords Search (AC自动机)

http://acm.hdu.edu.cn/showproblem.php?pid=2222 Keywords Search Problem Description In t...
  • cowboy90
  • cowboy90
  • 2013年10月05日 19:13
  • 339

HDU 2222 Keywords Search(AC自动机 模板)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2222 转自:http://www.cnblogs.com/kuangbin/p/3164106.h...
  • u012860063
  • u012860063
  • 2015年03月15日 21:50
  • 497

HDU---2222-Keywords Search(AC自动机)

G - Keywords Search Crawling in process... Crawling failed Time Limit:1000MS     Memory Limit:13...
  • qq978874169
  • qq978874169
  • 2015年11月06日 17:58
  • 173

hdU 2222 Keywords Search(AC自动机)

/* AC AC自动机问题 参考: http://www.cppblog.com/mythit/archive/2009/04/21/80633.html */ #include using na...
  • lhshaoren
  • lhshaoren
  • 2012年05月15日 09:08
  • 366
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【AC自动机】HDU2222Keywords Search
举报原因:
原因补充:

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