zoukankan      html  css  js  c++  java
  • hdu2896 ac自动机

    这题还是ac自动机裸题,只不过就是格式很烦人

    有几个坑点:输入可能有空格,ascll可见字符从32开始到126有95个

    wa点,用string输入,不能含空格,用scanf输入字符数组时没有memset,每次计算set里面的末尾值之后就清空了

    #include<bits/stdc++.h>
    #define fi first
    #define se second
    #define mp make_pair
    #define pb push_back
    #define pii pair<int,int>
    #define C 0.5772156649
    #define pi acos(-1.0)
    #define ll long long
    #define mod 1000000007
    #define ls l,m,rt<<1
    #define rs m+1,r,rt<<1|1
    
    using namespace std;
    
    const double g=10.0,eps=1e-7;
    const int N=100000+10,maxn=60000+10,inf=0x3f3f3f;
    
    struct Trie{
        int fail[N],Next[N][95];
        set<int>cnt[N];
        int tot,root,sum;
        int newnode()
        {
            for(int i=0;i<95;i++)
                Next[tot][i]=-1;
            cnt[tot].clear();
            return tot++;
        }
        void init()
        {
            sum=0;
            tot=0;
            root=newnode();
        }
        void insertstring(char *s,int k)
        {
            int now=root,len=strlen(s);
            for(int i=0;i<len;i++)
            {
                if(Next[now][s[i]-' ']==-1)
                    Next[now][s[i]-' ']=newnode();
                now=Next[now][s[i]-' '];
            }
            cnt[now].insert(k);
        }
        void build()
        {
            queue<int>q;
            fail[root]=root;
            for(int i=0;i<95;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<95;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]);
                    }
                }
            }
        }
        void query(char *s,int k)
        {
            int now=root,len=strlen(s);
            set<int>ans;
            for(int i=0;i<len;i++)
            {
                now=Next[now][s[i]-' '];
                int temp=now;
                while(temp!=root)
                {
                    for(auto x : cnt[temp])
                        ans.insert(x);
                    temp=fail[temp];
                }
            }
            if(ans.size()==0)return ;
            printf("web %d:",k);
            for(auto x : ans)
                printf(" %d",x);
            puts("");
            sum++;
        }
    };
    Trie ac;
    char s[N];
    int main()
    {
       /* ios::sync_with_stdio(false);
        cin.tie(0);*/
        int n;
        scanf("%d",&n);
        ac.init();
        getchar();
        for(int i=1;i<=n;i++)
        {
            int cnt=0;
            char p;
            memset(s,0,sizeof s);
            while((p=getchar())!='
    ')
            {
                s[cnt++]=p;
            }
            ac.insertstring(s,i);
        }
        ac.build();
        int k;
        scanf("%d",&k);
        getchar();
        for(int i=1;i<=k;i++)
        {
            int cnt=0;
            char p;
            memset(s,0,sizeof s);
            while((p=getchar())!='
    ')
            {
                s[cnt++]=p;
            }
         /*   cout<<strlen(s)<<endl;
            printf("%s
    ",s);*/
            ac.query(s,i);
        }
        printf("total: %d
    ",ac.sum);
        return 0;
    }
    /********************
    3
    aaa
    bbb
    ccc
    2
    aaabbbccc
    abbb cc
    ********************/
    View Code
  • 相关阅读:
    iOS下JS与OC互相调用(一)--UIWebView 拦截URL
    【转】git 删除本地分支和远程分支、本地代码回滚和远程代码库回滚
    Spring MVC的一些学习笔记-入门配置和HttpMessageConverter
    xrdp 安装后 WINDOWS远程登录出错
    树莓派(raspberry pi)更改键盘布局
    说说qwerty、dvorak、colemak三种键盘布局
    手机就能申请摇号 杭州市小客车摇号功能全新上线
    几种你不知道的获取浙A牌照的方法
    【转】则表达式匹配居民身份证
    机房收费系统之—如何查询两个日期之间的数据
  • 原文地址:https://www.cnblogs.com/acjiumeng/p/7552517.html
Copyright © 2011-2022 走看看