青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

fzu 2005 Computer Virus on Planet Pandora (The 35th ACM/ICPC Asia Regional Fuzhou Site) AC自動機

題意:
給出一些病毒的特征串,如果一個程序(或者將程序反轉)中出現了某個病毒的特征串,則該程序被這個病毒感染了。給出若干病毒串,一個程序串,問改程序被多少種病毒感染了?
解法:
比賽的時候模板有bug,WA到死,竟然這個用了數月的模板之前還神奇的通過了N道自動機的題目,不可思議。。
一道非常裸的自動機,將程序串正反匹配一遍既得答案。
自動機節點結構如下:
1 struct node
2 {
3    unsigned long long bit[4];
4    struct node *nxt[26];
5    struct node *pre;
6 };
用位記錄以當前節點為后綴的子串包含了多少種模式串,位壓縮策略如下:
1 void setbit(unsigned long long bit[],int pos)
2 {
3    bit[pos/64]|=(1ll<<(pos%64));
4 }
自動機轉移策略(計算前綴指針):
 1 void makepre()
 2 {
 3     struct node *p=buf;
 4     int s=-1,e=-1,i;
 5     for(i=0;i<26;i++)
 6       if(p->nxt[i])
 7       {
 8          p->nxt[i]->pre=p;
 9          q[++e]=p->nxt[i];
10       }
11       else
12           p->nxt[i]=p;
13     while(s!=e)
14     {
15        p=q[++s];
16        for(i=0;i<4;i++)
17          (p->bit[i])|=(p->pre->bit[i]);
18        for(i=0;i<26;i++)
19        {
20           struct node *pre=p->pre;
21           while(!(pre->nxt[i])) pre=pre->pre;
22           if(p->nxt[i])
23           {
24              p->nxt[i]->pre=pre->nxt[i];
25              q[++e]=p->nxt[i];
26           }
27           else
28              p->nxt[i]=pre->nxt[i];
29        }
30     }
31 }

整個程序(這次就當重新修正下模板。。用標準C語言寫下自動機):
  1 # include <stdio.h>
  2 # include <stdlib.h>
  3 # define N 300000
  4 # define root 0
  5 # include <string.h>
  6 struct node
  7 {
  8    unsigned long long bit[4];
  9    struct node *nxt[26];
 10    struct node *pre;
 11 }buf[N];
 12 char str[5200000],tstr[5200000];
 13 int c;
 14 struct node *q[N];
 15 void clear(struct node *pos)
 16 {
 17    memset(pos->bit,0,sizeof(pos->bit));
 18    memset(pos->nxt,NULL,sizeof(pos->nxt));
 19    pos->pre=NULL;
 20 }
 21 void init()
 22 {
 23    c=1;
 24    clear(buf);
 25 }
 26 void setbit(unsigned long long bit[],int pos)
 27 {
 28    bit[pos/64]|=(1ll<<(pos%64));
 29 }
 30 void insert(char *str,int id)
 31 {
 32    int i,len=strlen(str);
 33    struct node *p=buf;
 34    for(i=0;i<len;i++)
 35    {
 36       if(!(p->nxt[str[i]-'A']))
 37       {
 38           p->nxt[str[i]-'A']=&buf[c++];
 39           clear(p->nxt[str[i]-'A']);
 40       }
 41       p=p->nxt[str[i]-'A'];
 42    }
 43    setbit(p->bit,id);
 44 }
 45 void makepre()
 46 {
 47     struct node *p=buf;
 48     int s=-1,e=-1,i;
 49     for(i=0;i<26;i++)
 50       if(p->nxt[i])
 51       {
 52          p->nxt[i]->pre=p;
 53          q[++e]=p->nxt[i];
 54       }
 55       else
 56           p->nxt[i]=p;
 57     while(s!=e)
 58     {
 59        p=q[++s];
 60        for(i=0;i<4;i++)
 61          (p->bit[i])|=(p->pre->bit[i]);
 62        for(i=0;i<26;i++)
 63        {
 64           struct node *pre=p->pre;
 65           while(!(pre->nxt[i])) pre=pre->pre;
 66           if(p->nxt[i])
 67           {
 68              p->nxt[i]->pre=pre->nxt[i];
 69              q[++e]=p->nxt[i];
 70           }
 71           else
 72              p->nxt[i]=pre->nxt[i];
 73        }
 74     }
 75 }
 76 int match()
 77 {
 78    struct node *p=buf;
 79    unsigned long long res[4];
 80    int len=strlen(str),i,j,ans=0;
 81    memset(res,0,sizeof(res));
 82    for(i=0;i<len;i++)
 83    {
 84       p=p->nxt[str[i]-'A'];
 85       for(j=0;j<4;j++)
 86          res[j]|=(p->bit[j]);
 87    }
 88    strrev(str);
 89    p=buf;
 90     for(i=0;i<len;i++)
 91    {
 92       p=p->nxt[str[i]-'A'];
 93       for(j=0;j<4;j++)
 94          res[j]|=(p->bit[j]);
 95    }
 96    for(i=0;i<4;i++)
 97      while(res[i])
 98      {
 99         ans+=(res[i]&1);
100         res[i]>>=1;
101      }
102    return ans;
103 }
104 void decompress()
105 {
106    int p=0,len=strlen(tstr),i;
107    for(i=0;i<len;i++)
108    {
109        if(tstr[i]=='[')
110        {
111           int j,num;
112           char ch;
113           for(j=i+1;j<len&&tstr[j]!=']';j++);
114           ch=tstr[j-1];
115           tstr[j-1]='\0';
116           num=atoi(tstr+i+1);
117           i=j;
118           while(num--)
119             str[p++]=ch;
120        }
121        else
122           str[p++]=tstr[i];
123    }
124    str[p]='\0';
125 }
126 int main()
127 {
128    int test;
129    scanf("%d",&test);
130    while(test--)
131    {
132       int n,i;
133       init();
134       scanf("%d",&n);
135       for(i=0;i<n;i++)
136       {
137          char tmp[1005];
138          scanf("%s",tmp);
139          insert(tmp,i);
140       }
141       makepre();
142       scanf("%s",tstr);
143       decompress();
144       printf("%d\n",match());
145    }
146    return 0;
147 }
148 
149 


posted on 2010-12-07 01:36 yzhw 閱讀(479) 評論(0)  編輯 收藏 引用 所屬分類: string algorithm

<2010年12月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

導航

統計

公告

統計系統

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美性片在线观看| 亚洲一区免费视频| 夜夜夜久久久| 亚洲精品网站在线播放gif| 黑人操亚洲美女惩罚| 亚洲欧洲精品一区二区| 久久偷窥视频| 久久午夜视频| 欧美肥婆bbw| 日韩一二三区视频| 亚洲午夜精品一区二区| 亚洲一区二区欧美日韩| 欧美在线观看一二区| 久久久久在线观看| 欧美精品在线一区| 欧美午夜精品久久久| 国产伦理精品不卡| 伊人精品成人久久综合软件| 亚洲高清在线观看| 国产精品免费一区二区三区在线观看 | 欧美一区二区啪啪| 欧美专区第一页| 久久综合狠狠综合久久激情| 欧美国产成人精品| 亚洲欧美日韩综合国产aⅴ| 噜噜噜躁狠狠躁狠狠精品视频 | 在线中文字幕不卡| 久久久久一区| 一本色道久久综合| 久久精品二区三区| 欧美性淫爽ww久久久久无| 一区二区视频免费在线观看| 亚洲一区视频| 亚洲国产婷婷综合在线精品 | 欧美激情一区在线| 亚洲少妇诱惑| 久久综合久色欧美综合狠狠| 欧美日韩一区二区三区高清| 国产视频一区二区三区在线观看| 亚洲精品美女久久久久| 亚洲精品一区二区三区樱花| 久久久久成人精品| 亚洲日本理论电影| 香蕉成人伊视频在线观看| 美日韩精品视频免费看| 国产精品久久久久999| 亚洲国产成人一区| 欧美一级视频| 亚洲人体1000| 久久中文久久字幕| 国产精品久久久久免费a∨大胸| 亚洲专区国产精品| 久久激情中文| 久久狠狠婷婷| 99热精品在线| 亚洲看片网站| 久久精品亚洲乱码伦伦中文| 欧美成人一区在线| 亚洲尤物视频网| 久久久久国产一区二区三区四区| 亚洲欧美电影院| 欧美一区二区网站| 久久久久国产精品www| 国产精品高清一区二区三区| 在线免费观看日本一区| 欧美在线免费看| 一本一本a久久| 久久男人资源视频| 国产欧美日韩三级| 亚洲男女自偷自拍图片另类| 最新亚洲电影| 久久精品一区蜜桃臀影院| 欧美偷拍一区二区| 日韩视频亚洲视频| 免费一级欧美片在线观看| 欧美激情久久久久久| 亚洲欧美日韩专区| 亚洲伊人观看| 欧美色图天堂网| 亚洲免费观看在线视频| 久久久综合网| 久久不射中文字幕| 一本色道久久综合一区| 欧美精品一卡| 亚洲精品国产精品国自产观看浪潮 | 欧美国产日韩视频| 国外成人网址| 午夜欧美精品久久久久久久| 一区二区毛片| 国产精品成人午夜| 亚洲欧美一区二区视频| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲国产日韩一区二区| 亚洲欧美欧美一区二区三区| 欧美h视频在线| 亚洲国产专区| 亚洲日本成人| 欧美啪啪成人vr| 一本色道久久综合亚洲二区三区 | 国产精品v片在线观看不卡| 亚洲四色影视在线观看| 亚洲无限av看| 国内成人精品视频| 亚洲午夜精品视频| 一本色道久久综合亚洲精品不卡| 欧美在线视频一区| 制服丝袜亚洲播放| 久久精品国产精品亚洲综合| 午夜精品久久久久影视| 国产日韩欧美黄色| 久久国产精品第一页| 亚洲视频精选在线| 国内精品免费午夜毛片| 亚洲国产一二三| 国产精品自在线| 欧美激情按摩| 国产精品一区二区三区四区五区 | 亚洲人成7777| 国产欧美午夜| 亚洲电影免费在线观看| 欧美日韩一区在线| 久久综合一区| 亚洲美女电影在线| 国产乱肥老妇国产一区二| 麻豆精品视频| 久久视频一区| 亚洲麻豆视频| 欧美在线观看视频| 亚洲欧洲日本一区二区三区| 国产精品99久久久久久久女警| 国产精品三级视频| 亚洲成色777777女色窝| 欧美日韩中文字幕精品| 久久精品国产亚洲高清剧情介绍| 欧美凹凸一区二区三区视频| 性伦欧美刺激片在线观看| 亚洲靠逼com| 国产一区二区视频在线观看| 亚洲区国产区| 亚洲国产精品久久久久秋霞蜜臀 | 麻豆精品在线视频| 性做久久久久久免费观看欧美| 欧美 日韩 国产在线| 久久久综合精品| 国产精品久久久久三级| 亚洲经典在线看| 伊人伊人伊人久久| 午夜精品理论片| 国产伦精品一区| 亚洲毛片在线免费观看| 亚洲国产精品久久精品怡红院| 午夜精品免费| 亚洲香蕉成视频在线观看| 免费观看亚洲视频大全| 性做久久久久久久免费看| 欧美日韩国产精品专区| 亚洲国产日韩美| 日韩视频一区二区三区在线播放免费观看 | 一本久道久久综合婷婷鲸鱼| 久久成人综合网| 国产精品毛片a∨一区二区三区|国| 亚洲精品乱码久久久久| 国产私拍一区| 性久久久久久久久| 999在线观看精品免费不卡网站| 欧美日韩亚洲免费| 91久久国产综合久久| 亚洲国产高清一区二区三区| 久久久99爱| 欧美激情一区二区三区在线视频 | 欧美国产欧美综合| 一区二区视频在线观看| 久久在线免费观看| 免费在线观看日韩欧美| 亚洲国产三级| 欧美日韩国产精品一区二区亚洲 | 欧美韩国一区| 亚洲三级国产| 欧美日韩一区二区三区视频| 日韩亚洲视频| 亚洲欧洲av一区二区三区久久| 国产精品久久久久久模特| 在线天堂一区av电影| 午夜精品视频在线观看一区二区 | 国产欧美不卡| 久久久国产一区二区三区| 欧美国产乱视频| 国产一区二区中文| 久久精品综合一区| 国产欧美日韩精品丝袜高跟鞋| 亚洲一区二区成人| 久久久国产精品亚洲一区| 国产欧美日韩激情| 欧美在线91| 亚洲精品久久久久久久久久久久久 | 久久久国产精品一区| 国产一区二区三区久久精品| 欧美va天堂va视频va在线| 亚洲精品国产精品久久清纯直播 | 久久精品国产77777蜜臀|