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

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>
            午夜精品久久久久久久久| 欧美日韩大片| 亚洲精品一区二区三区四区高清 | 亚洲精华国产欧美| 欲香欲色天天天综合和网| 在线观看精品视频| 亚洲精品视频在线观看免费| 99精品欧美一区| 亚洲在线不卡| 久久嫩草精品久久久精品| 欧美成人日本| 在线一区免费观看| 欧美中文字幕视频| 免费看的黄色欧美网站| 欧美日本精品| 国产欧美日韩三区| 亚洲动漫精品| 亚洲欧美文学| 欧美高清在线视频| 一本色道**综合亚洲精品蜜桃冫| 先锋亚洲精品| 欧美美女福利视频| 好吊日精品视频| 中日韩男男gay无套| 久久国产精品黑丝| 亚洲久久在线| 久久裸体视频| 国产精品久久久久久模特| 一区二区三区在线视频播放| 在线亚洲激情| 欧美激情欧美激情在线五月| 狠狠色狠狠色综合日日91app| 亚洲欧美日韩精品久久久久| 久久久久久久久久久一区| 欧美国产1区2区| 国产在线欧美| 亚洲一区二区成人在线观看| 欧美va亚洲va国产综合| 亚洲永久免费av| 欧美日韩免费一区| 亚洲激情视频网站| 巨胸喷奶水www久久久免费动漫| 亚洲图片激情小说| 你懂的网址国产 欧美| 国内精品久久久久久影视8| 亚洲在线观看免费| 亚洲激情社区| 久久九九热re6这里有精品| 欧美性片在线观看| 亚洲精品日韩激情在线电影| 久久综合色88| 性久久久久久久| 国产九九精品视频| 午夜精品福利在线| 在线视频精品一区| 欧美视频一二三区| 在线综合+亚洲+欧美中文字幕| 亚洲二区在线| 欧美成人午夜激情视频| 亚洲国产成人精品久久| 免费成人性网站| 久久久免费精品视频| 国内精品久久久久久 | 亚洲免费av电影| 欧美成人精品1314www| 欧美中文在线观看| 精品成人a区在线观看| 久久一区免费| 美女尤物久久精品| 亚洲日本免费| 亚洲免费av观看| 欧美特黄一级| 欧美亚洲一区三区| 欧美一区二区三区四区在线 | 亚洲电影免费观看高清| 快射av在线播放一区| 欧美专区18| 亚洲国产美国国产综合一区二区| 亚洲高清久久| 欧美日韩视频在线| 亚洲欧美春色| 久久精彩视频| 亚洲精选视频免费看| 99成人精品| 国产日韩在线一区| 欧美成人国产| 性欧美暴力猛交69hd| 农村妇女精品| 欧美福利一区二区| 亚洲午夜av在线| 西西裸体人体做爰大胆久久久| 黄色精品网站| 亚洲国产天堂网精品网站| 国产精品捆绑调教| 久热精品视频在线| 欧美日韩成人激情| 欧美jizzhd精品欧美喷水| 亚洲在线中文字幕| 久久嫩草精品久久久精品| 99精品欧美| 久久久久国产精品午夜一区| 亚洲一区二区3| 久久久欧美一区二区| 亚洲视频axxx| 欧美不卡在线视频| 西瓜成人精品人成网站| 欧美ed2k| 亚洲你懂的在线视频| 一本一本久久a久久精品综合麻豆| 国产亚洲成av人在线观看导航| 久久久久在线| 欧美日韩www| 欧美α欧美αv大片| 国产精品成人v| 欧美激情视频一区二区三区在线播放| 国产精品福利在线| 91久久精品一区二区三区| 国产日韩欧美精品| 99av国产精品欲麻豆| 亚洲国产欧美在线| 久久精品一区二区三区四区 | 亚洲国产成人在线| 国产精品一区二区在线观看网站 | 在线视频欧美一区| 亚洲欧洲日产国产综合网| 欧美一级淫片播放口| 亚洲欧美日韩精品在线| 欧美精品七区| 亚洲国产欧美不卡在线观看| 黄色精品一二区| 欧美在线1区| 久久久噜噜噜久久久| 国产精品自拍网站| 亚洲精品免费电影| 亚洲视频 欧洲视频| 国产亚洲精品久久久| 亚洲精品视频一区二区三区| 亚洲承认在线| 久久久免费av| 亚洲第一在线综合在线| 亚洲高清视频的网址| 日韩视频中文字幕| 亚洲国产精品123| 亚洲一区二区视频在线| 一区二区日韩精品| 欧美国产精品人人做人人爱| 亚洲国产精品一区制服丝袜| 亚洲高清视频在线| 欧美va亚洲va日韩∨a综合色| 亚洲第一色中文字幕| 99re66热这里只有精品3直播| 欧美高清不卡| 一区二区三区**美女毛片| 午夜一区二区三区不卡视频| 欧美成人精品1314www| 最新成人av在线| 亚洲在线电影| 精品999网站| 欧美精品1区2区| 一区二区三区不卡视频在线观看| 午夜视频在线观看一区二区| 国产在线视频欧美一区二区三区| 久久免费国产| av成人毛片| 老**午夜毛片一区二区三区| 国产午夜精品视频免费不卡69堂| 99这里有精品| 欧美专区在线观看| 欧美黑人多人双交| 亚洲日本va在线观看| 欧美日本三级| 亚洲一区二区伦理| 久久久xxx| 亚洲精品一区二区三区婷婷月| 欧美日韩一二区| 久久av资源网站| 99精品热6080yy久久| 久久躁日日躁aaaaxxxx| 夜夜嗨一区二区| 狠狠色噜噜狠狠狠狠色吗综合| 欧美日韩亚洲在线| 久久久噜噜噜久噜久久| 亚洲视频精选在线| 欧美成va人片在线观看| 午夜精品三级视频福利| 亚洲精品国偷自产在线99热| 国产精品私拍pans大尺度在线 | 在线观看视频日韩| 国产精品videosex极品| 美女在线一区二区| 午夜精品久久久久久久男人的天堂| 欧美黑人国产人伦爽爽爽| 小嫩嫩精品导航| 一区二区三区四区蜜桃| 亚洲激情午夜| 亚洲二区三区四区| 黄色亚洲免费| 国内揄拍国内精品少妇国语| 国产欧美一区二区精品秋霞影院| 欧美日韩一级黄|