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

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>
            欧美精品一区二区三区很污很色的| 亚洲欧美日韩精品| 久久一区二区三区超碰国产精品| 亚洲一区中文字幕在线观看| 亚洲少妇在线| 亚洲欧美日本国产有色| 欧美一区二区视频免费观看| 久久久久久久久久久久久9999 | 国产精品视频一区二区高潮| 国产精品久久9| 国产无一区二区| 亚洲福利视频一区二区| 一本久道综合久久精品| 欧美一区二区三区免费视频| 免费观看30秒视频久久| 亚洲经典视频在线观看| 亚洲一区二区三区在线看 | 欧美中在线观看| 免费在线观看日韩欧美| 欧美色网在线| 一区二区视频欧美| 一本久道久久久| 久久人人爽国产| 亚洲另类春色国产| 久久国产色av| 欧美性猛交xxxx免费看久久久| 国产亚洲精品高潮| 一区二区三区四区五区视频| 久久久999精品免费| 91久久精品美女高潮| 欧美一区二区精品久久911| 欧美二区视频| 国产亚洲一区在线| 亚洲永久免费| 亚洲国产精品va在线观看黑人| 亚洲欧美日本精品| 欧美日韩在线另类| 亚洲激情成人网| 久久深夜福利| 午夜在线电影亚洲一区| 欧美日韩一卡二卡| 亚洲人成免费| 欧美国产大片| 久久夜色精品国产亚洲aⅴ| 欧美一区二区三区四区在线观看地址| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美成年人网| 欧美一区91| 国产精品视频自拍| 亚洲永久字幕| 99这里有精品| 欧美三日本三级三级在线播放| 亚洲日韩成人| 亚洲国产高清高潮精品美女| 久久久成人网| 亚洲国产成人porn| 欧美高清视频免费观看| 久热精品视频在线免费观看| 黑人一区二区三区四区五区| 久久久www成人免费无遮挡大片| 中文亚洲视频在线| 欧美吻胸吃奶大尺度电影| 中文欧美日韩| 亚洲在线成人精品| 国产亚洲第一区| 久久久美女艺术照精彩视频福利播放 | 国产精品另类一区| 性18欧美另类| 羞羞漫画18久久大片| 国产麻豆9l精品三级站| 久久成人国产| 久久只有精品| 一区二区三区蜜桃网| 一本大道久久a久久综合婷婷 | 国产精品你懂的在线| 亚洲已满18点击进入久久| 亚洲少妇中出一区| 国产有码一区二区| 欧美1区2区视频| 欧美日韩不卡在线| 欧美在线免费观看视频| 欧美主播一区二区三区美女 久久精品人| 国产欧美亚洲日本| 久久综合九色综合欧美就去吻| 久久久精品国产免大香伊| 最新国产乱人伦偷精品免费网站| 亚洲精品久久7777| 国产精自产拍久久久久久| 美女露胸一区二区三区| 欧美视频免费在线| 免费成人黄色av| 国产精品jvid在线观看蜜臀| 久久夜色精品一区| 欧美日韩亚洲视频一区| 久久天天躁狠狠躁夜夜爽蜜月| 欧美成人免费视频| 久久激情视频久久| 欧美激情影音先锋| 久久精品在这里| 欧美日本在线播放| 老司机免费视频久久| 欧美午夜欧美| 欧美大片免费观看| 国产日韩欧美一区| 国产亚洲一本大道中文在线| 亚洲欧美日韩在线高清直播| 久久天天躁狠狠躁夜夜爽蜜月| 中文日韩欧美| 久久亚洲精品一区| 欧美伊人久久大香线蕉综合69| 麻豆久久精品| 久久久久久97三级| 国产精品青草久久| 亚洲精品国产精品国自产观看| 国产一区二区三区精品久久久| 99在线热播精品免费99热| 亚洲区欧美区| 久久久久女教师免费一区| 欧美一区二区三区视频在线| 欧美区视频在线观看| 欧美暴力喷水在线| 国产曰批免费观看久久久| 亚洲一区二区三区在线观看视频| 一本色道久久99精品综合 | 女同性一区二区三区人了人一| 国产精品福利在线| 99riav久久精品riav| 91久久精品美女高潮| 久久精品国产欧美激情| 欧美一区网站| 国产女主播一区| 亚洲系列中文字幕| 午夜精品视频在线观看一区二区| 欧美精品国产一区| 亚洲国产欧美一区| 亚洲精品欧美极品| 欧美大学生性色视频| 欧美激情综合色| 亚洲老板91色精品久久| 欧美激情一区二区在线| 亚洲人成人一区二区三区| 亚洲精品在线免费观看视频| 男人天堂欧美日韩| 亚洲电影天堂av| 亚洲国产日韩欧美在线99| 美日韩精品免费| 亚洲激情电影在线| 中文一区字幕| 国产精品久久久久久av福利软件 | 很黄很黄激情成人| 久久激情视频| 欧美国产精品日韩| 日韩一级网站| 国产精品国产自产拍高清av王其 | 亚洲精品国产欧美| 亚洲欧美日韩精品综合在线观看| 国产精品激情电影| 久久xxxx精品视频| 欧美激情欧美激情在线五月| 亚洲人成7777| 国产精品视频yy9099| 精品69视频一区二区三区| 亚洲免费成人av| 中文亚洲视频在线| 国产日韩欧美一区二区三区在线观看 | 亚洲三级性片| 国产精品美腿一区在线看| 欧美亚洲视频| 农夫在线精品视频免费观看| 一区二区三区视频在线| 国产一区二区观看| 欧美激情影院| 欧美中文字幕第一页| 亚洲精品在线三区| 久久久成人网| 亚洲一区二区三区高清| 极品少妇一区二区三区精品视频| 欧美激情aⅴ一区二区三区| 亚洲在线观看视频网站| 欧美国产91| 久久久久久尹人网香蕉| 一区二区三区鲁丝不卡| 精品动漫3d一区二区三区免费| 国产精品99免费看| 久久久xxx| 亚洲欧美日韩视频一区| 亚洲日本无吗高清不卡| 久久综合伊人77777蜜臀| 亚洲欧美日韩国产综合| 亚洲精品一区二区三区福利| 国产欧美日韩不卡| 欧美日本一区| 欧美成人四级电影| 久久www免费人成看片高清| 国产在线播精品第三| 国产精品国产成人国产三级| 欧美肥婆bbw| 蜜桃av综合| 老牛嫩草一区二区三区日本| 午夜久久资源|