hdu 2222 Keywords Search (AC自动机)

原创 2015年07月07日 10:14:58
//可能有重复单词
# include <stdio.h>
# include <queue>
# include <string.h>
# include <algorithm>
using namespace std;
char str[110],a[1000010];
# define kind 26
struct node
{
    node *fail;
    node *next[kind];
    int cnt;//从根到此处是否是关键字,并且记录是多少个关键字的结尾
    node()
    {
        fail=NULL;
        cnt=0;
        for(int i=0;i<26;i++)
            next[i]=NULL;
      //  memset(next,0,sizeof(next));
    }

};
queue<node*>qq;
void Buildtree(node *root ,int index)
{
    node *p=root;
    int i=0,id;
    while(str[i])
    {
        id=str[i]-'a';
        if(p->next[id]==NULL)
            p->next[id]=new node();
        p=p->next[id];
        i++;
    }
    (p->cnt)++;///记录是多少个关键字的结尾
}
void bfs(node *root)
{
    while(!qq.empty())
        qq.pop();
    root->fail=NULL;
    qq.push(root);
    root->fail=NULL;
    node *tmp,*p;
    while(!qq.empty())
    {
        tmp=qq.front();
        qq.pop();
        p=NULL;
        for(int i=0;i<kind;i++)
        {
            if(tmp->next[i]!=NULL)
            {
                p=tmp->fail;
                while(p&&!p->next[i])
                    p=p->fail;
                if(!p)
                    tmp->next[i]->fail=root;
                else
                    tmp->next[i]->fail=p->next[i];
                qq.push(tmp->next[i]);
            }
        }
    }
}
int has[10010];
int Ac_run(node *root)
{
    int i=0,ans=0,id;
    node *p=root;
    while(a[i])
    {
        id=a[i]-'a';
        while(!p->next[id]&&p!=root)//跳转失败指针
            p=p->fail;
        p=p->next[id];
        if(!p)
            p=root;
        node *tmp=p;//p不动,temp计算后缀串
        while(tmp!=root&&tmp->cnt!=-1)
        {

                ans+=tmp->cnt;
                tmp->cnt=-1;///
               // has[tmp->cnt]=1;
                tmp=tmp->fail;
        }
        i++;

    }
    return ans;
}
int main()
{
    int t,n;
    while(~scanf("%d",&t))
    {
        while(t--)
        {
            node *root=new node();
            scanf("%d",&n);
            for(int i=1;i<=n;i++)
            {
                scanf("%s",str);
                Buildtree(root,i);
            }
            bfs(root);
         //   memset(has,0,sizeof(has));
            scanf("%s",a);
            printf("%d\n",Ac_run(root));

        }
    }
    return 0;
}

hdu 2222 ac自动机入门题 可以做模板

Keywords Search Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)...
  • hnust_xiehonghao
  • hnust_xiehonghao
  • 2013年06月19日 17:15
  • 7013

hdu 2222 AC自动机(可做模板)

Keywords Search Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others...
  • liu940204
  • liu940204
  • 2016年05月08日 16:03
  • 1702

AC自动机的简单Java实现

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

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
  • 113

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
  • 496

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
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:hdu 2222 Keywords Search (AC自动机)
举报原因:
原因补充:

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