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

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

題意:
給出一些病毒的特征串,如果一個程序(或者將程序反轉(zhuǎn))中出現(xiàn)了某個病毒的特征串,則該程序被這個病毒感染了。給出若干病毒串,一個程序串,問改程序被多少種病毒感染了?
解法:
比賽的時候模板有bug,WA到死,竟然這個用了數(shù)月的模板之前還神奇的通過了N道自動機的題目,不可思議。。
一道非常裸的自動機,將程序串正反匹配一遍既得答案。
自動機節(jié)點結(jié)構(gòu)如下:
1 struct node
2 {
3    unsigned long long bit[4];
4    struct node *nxt[26];
5    struct node *pre;
6 };
用位記錄以當前節(jié)點為后綴的子串包含了多少種模式串,位壓縮策略如下:
1 void setbit(unsigned long long bit[],int pos)
2 {
3    bit[pos/64]|=(1ll<<(pos%64));
4 }
自動機轉(zhuǎn)移策略(計算前綴指針):
 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年11月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

導航

統(tǒng)計

公告

統(tǒng)計系統(tǒng)

留言簿(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>
            欧美一区二区三区婷婷月色| 国产精品久久97| 亚洲精品美女久久久久| 久久久九九九九| 蜜臀va亚洲va欧美va天堂| 久久九九全国免费精品观看| 久色婷婷小香蕉久久| 欧美丰满高潮xxxx喷水动漫| 99精品热6080yy久久| 亚洲男同1069视频| 久久成人免费电影| 欧美精品18+| 国产欧美日韩激情| 亚洲人成网站在线观看播放| 亚洲永久精品大片| 蜜臀99久久精品久久久久久软件| 亚洲黄色有码视频| 午夜精品视频在线| 美女免费视频一区| 国产酒店精品激情| 亚洲毛片av在线| 久久精品二区| 日韩一级片网址| 久久久精品免费视频| 欧美午夜欧美| 亚洲电影在线免费观看| 亚洲欧美国产另类| 亚洲精品欧美| 欧美亚洲免费电影| 欧美日韩精品免费| 亚洲国产福利在线| 久久国产精品电影| 一区二区三区成人精品| 久久久久一本一区二区青青蜜月| 欧美午夜精品久久久久久人妖| 在线观看欧美成人| 亚洲国产精品久久久久久女王| 洋洋av久久久久久久一区| 亚洲免费在线视频| 欧美激情影音先锋| 亚洲大片av| 久久精品综合| 亚洲尤物在线视频观看| 欧美日韩一区二区三区在线观看免| 在线播放一区| 久久综合九色综合网站| 亚洲欧美日韩区| 国产精品永久免费视频| 亚洲欧美卡通另类91av | 欧美一区二区精品久久911| 欧美激情精品久久久久久免费印度 | 国产日韩欧美一区二区三区在线观看 | 亚洲午夜一区| 欧美午夜在线观看| 一区二区三区精品久久久| 亚洲成人在线视频网站| 免费观看亚洲视频大全| 亚洲国产欧美不卡在线观看| 麻豆精品视频在线观看视频| 欧美在线观看一区| 国内精品视频666| 免费一级欧美片在线播放| 久久久噜噜噜久久狠狠50岁| 在线观看91精品国产入口| 免费成人网www| 免费亚洲电影在线| 亚洲免费福利视频| 夜夜精品视频一区二区| 国产精品久久久久久久app | 欧美91大片| 免费中文日韩| 一区二区免费在线视频| 一区二区三区久久精品| 国产精品一区久久| 久久久久久久999精品视频| 久久久久国色av免费看影院 | 日韩西西人体444www| 99ri日韩精品视频| 国产欧美精品一区aⅴ影院| 久久影视三级福利片| 美女免费视频一区| 亚洲女性裸体视频| 久久成人人人人精品欧| 亚洲人成在线观看网站高清| 在线视频亚洲一区| 国产一区久久久| 欧美片在线观看| 欧美四级剧情无删版影片| 一区二区三区色| 亚洲欧美中文另类| 亚洲国产精品va在线看黑人 | 蜜臀va亚洲va欧美va天堂| 欧美日本一区| 久久九九热免费视频| 欧美国产视频在线观看| 欧美一区二区三区在线看| 麻豆成人91精品二区三区| 亚洲一区二区三区在线| 久久亚洲综合色| 香蕉精品999视频一区二区| 蜜桃久久精品乱码一区二区| 亚洲欧美一区二区视频| 欧美jizz19hd性欧美| 欧美一区二区在线免费播放| 欧美国产日韩一区二区在线观看 | 亚洲国产天堂久久综合网| 国产精品三级久久久久久电影| 免费欧美网站| 国产伦精品一区二区三区| 亚洲激情视频网站| 影音先锋日韩资源| 午夜精品在线观看| 亚洲天堂av图片| 欧美 日韩 国产在线| 久久久久久亚洲精品中文字幕| 欧美日韩免费高清一区色橹橹| 牛牛精品成人免费视频| 国产婷婷色一区二区三区在线 | 欧美一区久久| 小黄鸭精品aⅴ导航网站入口| 欧美精品午夜视频| 欧美激情a∨在线视频播放| 国产一区二区激情| 亚洲五月婷婷| 亚洲一区国产| 欧美视频导航| 一本色道久久综合亚洲精品按摩| 日韩视频不卡| 欧美日本一区| 亚洲人成毛片在线播放| 亚洲日韩第九十九页| 免费看精品久久片| 亚洲成色777777女色窝| 亚洲福利一区| 乱中年女人伦av一区二区| 毛片一区二区三区| 亚洲丶国产丶欧美一区二区三区| 久久久蜜桃精品| 欧美激情一区二区久久久| 亚洲精品小视频在线观看| 欧美日本在线观看| 在线亚洲电影| 欧美在线视频一区二区三区| 国产午夜精品一区二区三区视频| 欧美在线精品一区| 欧美大成色www永久网站婷| 欧美一区二区三区久久精品| 欧美黄色大片网站| 亚洲国产一二三| 99精品视频免费观看| 欧美日韩在线免费| 中文在线一区| 久久久久青草大香线综合精品| 在线成人www免费观看视频| 美女成人午夜| 99视频精品全部免费在线| 欧美在线观看一区二区三区| 精品成人国产在线观看男人呻吟| 免费在线日韩av| 亚洲一卡久久| 欧美成人久久| 亚洲综合国产| 一区二区三区在线高清| 欧美激情综合网| 亚洲女同精品视频| 亚洲东热激情| 欧美一区二区日韩| 亚洲精品欧美极品| 国产毛片久久| 欧美日韩不卡一区| 欧美资源在线| 日韩亚洲视频| 久久一区中文字幕| 亚洲欧美日本在线| 精品成人国产| 国产乱码精品1区2区3区| 免费在线亚洲欧美| 性伦欧美刺激片在线观看| 亚洲欧洲精品一区二区三区波多野1战4 | 亚洲激情视频网站| 国产精品伦理| 欧美高清视频一区二区三区在线观看| 亚洲桃色在线一区| 亚洲国产精品99久久久久久久久| 欧美一区二区免费观在线| 亚洲麻豆国产自偷在线| 狠狠干狠狠久久| 国产精品青草久久久久福利99| 男女激情久久| 欧美一区二区三区四区在线观看地址| 亚洲免费av电影| 亚洲国产成人精品久久久国产成人一区| 欧美尤物一区| 亚洲一级黄色片| 一区二区冒白浆视频| 亚洲清纯自拍| 最近中文字幕mv在线一区二区三区四区 | 亚洲国产精品va在看黑人| 国产视频不卡| 国产欧美精品日韩区二区麻豆天美|