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

AC自動(dòng)機(jī)

Posted on 2011-10-19 19:03 Mato_No1 閱讀(607) 評(píng)論(0)  編輯 收藏 引用
AC自動(dòng)機(jī)就是在Trie樹上加入一些失敗指針(fail,類似KMP中的next),使得它在某個(gè)結(jié)點(diǎn)失配的時(shí)候能夠轉(zhuǎn)移到該結(jié)點(diǎn)失敗指針指向的結(jié)點(diǎn)繼續(xù)匹配,從而實(shí)現(xiàn)多串匹配(單主串多子串)。

【1】Trie樹的結(jié)構(gòu):
首先是結(jié)點(diǎn)類型:
struct node {
    
int mul, ch[SZ], fail;
} T[MAXN];
其中SZ是字符集的大小,比如小寫字母集SZ=26,數(shù)字集SZ=10等。
另外這個(gè)mul表示的是該結(jié)點(diǎn)的重復(fù)次數(shù)(和平衡樹中的比較像),就是這個(gè)結(jié)點(diǎn)所對(duì)應(yīng)的字符串(從根到該結(jié)點(diǎn)路徑上的所有邊上的字符組成的字符串)出現(xiàn)了幾次。
(不過這種表示法MS不是很好……如果有卡空間的,比如結(jié)點(diǎn)總數(shù)和SZ之積達(dá)到了100M以上,而真正的邊又很少的時(shí)候……就囧掉了……而如果用指針的話在Linux下面又會(huì)CE掉……各位神犇來說一下怎么解決啊囧……)
然后,Trie樹的0號(hào)結(jié)點(diǎn)(T[0])是空結(jié)點(diǎn)(用來代替指針中的NULL),因此真正結(jié)點(diǎn)下標(biāo)從1開始。1號(hào)結(jié)點(diǎn)(T[1])一般都作為根結(jié)點(diǎn),所以下面直接寫#define root 1。
還有(這句話是除草用的……)Trie樹的字符全部都在邊上而不在點(diǎn)上,因此T[x].ch[c]其實(shí)指的是“結(jié)點(diǎn)x引出的字符為c的邊所指向的結(jié)點(diǎn)”,簡(jiǎn)稱結(jié)點(diǎn)x的c子結(jié)點(diǎn)。

【2】自動(dòng)機(jī)的建立:
首先要建立Trie樹(也就是在空的Trie樹上插入所有要匹配的子串)。這個(gè)隨便搞一下就傻掉了,因此直接上代碼:
void ins()
{
    
int len = s0.length(), x = root, c;
    re(i, len) {
        c 
= s0[i] - 97;
        
if (!T[x].ch[c]) {T[x].ch[c] = ++N; T[N].mul = 0; re(j, SZ) T[N].ch[j] = 0;}
        x 
= T[x].ch[c];
    }
    T[x].mul
++;
}
這里string s0是待插入的字符串,定義成全局變量,因?yàn)樵趨?shù)中出現(xiàn)string有可能爆掉。

然后就是建立自動(dòng)機(jī)了。
這一過程其實(shí)是用BFS遍歷來實(shí)現(xiàn)的。首先,T[root].fail=0(root也是整棵樹中唯一的fail為0的結(jié)點(diǎn))并將root入隊(duì)。下面按照BFS的順序依次取出隊(duì)所有的點(diǎn),對(duì)于結(jié)點(diǎn)i,若它存在k子結(jié)點(diǎn)j(也就是j=T[i].ch[k],且j≠0),則結(jié)點(diǎn)j入隊(duì),并計(jì)算j的失敗指針fail,方法:從T[i].fail(不是i)開始不斷上溯,直到找到一個(gè)存在k子結(jié)點(diǎn)的結(jié)點(diǎn)或者到root都木有找到(結(jié)點(diǎn)下標(biāo)為0,即NULL)。若找到了一個(gè)存在k子結(jié)點(diǎn)的結(jié)點(diǎn)x,則將T[j].fail置為T[x].ch[k],否則(直到root都木有找到),T[j].fail=root。

到這里失敗指針的用處就顯現(xiàn)了:如果匹配到結(jié)點(diǎn)x的時(shí)候失配(即接下來的一個(gè)字符是c而T[x].ch[c]=0),可以立刻轉(zhuǎn)到T[x].fail進(jìn)行匹配,因?yàn)門[x].fail有以下三個(gè)特征:
<1>其深度嚴(yán)格小于x的深度;
<2>其代表的字符串一定是x代表的字符串的后綴;
<3>該結(jié)點(diǎn)一定是滿足條件<1><2>的所有結(jié)點(diǎn)中深度最小的結(jié)點(diǎn);

代碼:
void mkf()
{
    Q[
0= root; T[root].fail = 0;
    
int i, j, x;
    
for (int front=0, rear=0; front<=rear; front++) {
        i 
= Q[front];
        re(k, SZ) 
if (j = T[i].ch[k]) {
            x 
= T[i].fail;
            
while (x && !T[x].ch[k]) x = T[x].fail;
            
if (x) T[j].fail = T[x].ch[k]; else T[j].fail = root;
            Q[
++rear] = j;
        }
    }
}

【3】匹配過程:
在有了失敗指針時(shí),其匹配過程就和KMP差不多了。
設(shè)主串為A(代碼中同),依次掃描A[0..A.length()-1]進(jìn)行匹配。設(shè)目前匹配到了第i位,A[i]=c,當(dāng)前結(jié)點(diǎn)為x。匹配過程中將進(jìn)行以下操作:
<1>成功匹配(T[x]有c子結(jié)點(diǎn)),則進(jìn)入T[x]的c子結(jié)點(diǎn);
<2>失配(T[x]無(wú)c子結(jié)點(diǎn)),則從T[x].fail開始,沿著失敗指針上溯,直到找到一個(gè)有c子結(jié)點(diǎn)的結(jié)點(diǎn)為止。如果到了root都木有找到這樣的結(jié)點(diǎn),則停止在root處;
<3>設(shè)立結(jié)點(diǎn)y,從當(dāng)前的結(jié)點(diǎn)x開始不斷上溯到root(注意root也要算,因?yàn)樽哟锌赡苡锌沾瑢⒅虚g所有結(jié)點(diǎn)的mul值累加進(jìn)最終結(jié)果(表示這些字符串在主串中出現(xiàn)了,統(tǒng)計(jì)次數(shù)),如果題目中要求統(tǒng)計(jì)不重復(fù)的子串個(gè)數(shù)(如HDU2222),則在累加之后將它們?nèi)恐脼?,防止下次再次累加。這一步操作實(shí)質(zhì)上就是統(tǒng)計(jì)A中所有以A[i]為右端點(diǎn)的子串個(gè)數(shù)。

這樣,整個(gè)過程就傻掉了。

代碼:
void solve()
{
    
int len = A.length(), x = root, y, c; res = 0;
    re(i, len) {
        c 
= A[i] - 97;
        
while (x && !T[x].ch[c]) x = T[x].fail;
        
if (!x) x = root; else x = T[x].ch[c];
        y 
= x;
        
while (y) {res += T[y].mul; T[y].mul = 0; y = T[y].fail;}
    }
}

有關(guān)例題:
【1】HDU2222
裸的多串匹配問題,模板題;
有關(guān)該題的詳細(xì)資料(包括易疵點(diǎn))見這里
【2】HDU2896
比2222稍難一些,但還是模板題。注意這題的子串木有重復(fù)的,因此mul可以設(shè)為bool。
【3】HDU3065
統(tǒng)計(jì)每個(gè)子串出現(xiàn)的次數(shù)(可以重復(fù)),也是模板題。
以上三題均不卡空間。

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            洋洋av久久久久久久一区| 久久久亚洲精品一区二区三区| 亚洲女同在线| 亚洲免费中文字幕| 欧美一级片在线播放| 香蕉久久一区二区不卡无毒影院 | 99成人在线| 日韩亚洲在线观看| 亚洲欧美日韩天堂| 久久久久国产精品一区| 免费亚洲一区| 欧美日韩国产成人在线观看| 欧美视频在线一区二区三区| 国产免费成人av| 一区免费观看| 中文欧美字幕免费| 久久人人精品| 日韩小视频在线观看| 久久av一区| 欧美精品自拍| 黄色在线一区| 亚洲女同同性videoxma| 免费久久精品视频| 亚洲伦理在线| 久久久人成影片一区二区三区观看 | 黄色精品一区| 日韩视频在线观看一区二区| 久久国产高清| 亚洲日本va在线观看| 亚洲欧美日韩国产精品| 免费亚洲婷婷| 黄色一区三区| 亚洲欧美日韩国产一区二区| 欧美电影免费观看高清| 亚洲综合欧美| 欧美日韩成人一区二区三区| 黑人操亚洲美女惩罚| 亚洲一二三区在线| 亚洲国产精品悠悠久久琪琪 | 欧美激情在线狂野欧美精品| 国产日韩欧美一区二区三区在线观看 | 欧美精品一区二区三| 国模精品娜娜一二三区| 亚洲综合色噜噜狠狠| 亚洲精品一线二线三线无人区| 久久久夜夜夜| 一区二区三区中文在线观看| 久久精品首页| 性欧美精品高清| 国产精品一级| 性做久久久久久| 亚洲香蕉伊综合在人在线视看| 欧美激情国产精品| 日韩视频免费| 99精品热视频| 国产精品久久久久久久久免费| 一区二区激情| 夜夜夜久久久| 国产精品美女主播| 亚洲欧美国产制服动漫| 亚洲一区二区精品在线| 国产精品无码永久免费888| 亚洲免费影视第一页| 宅男噜噜噜66国产日韩在线观看| 欧美日韩成人一区二区三区| 在线视频中文亚洲| 亚洲免费观看高清在线观看| 欧美日韩视频专区在线播放| 一区二区三区四区五区精品视频| 日韩视频久久| 国产精品va| 久久国产精品黑丝| 午夜精品久久久久久久99水蜜桃| 亚洲电影视频在线| 欧美影院成人| 免费成人黄色av| 亚洲在线观看免费视频| 久热精品视频在线| 国一区二区在线观看| 久久久久久亚洲精品杨幂换脸 | 国产精品视屏| 午夜精品www| 欧美亚洲日本网站| 好吊日精品视频| 亚洲高清视频一区| 久久综合五月| 99在线精品观看| 亚洲视频在线一区| 激情综合网激情| 亚洲免费激情| 国产主播精品在线| 亚洲区第一页| 国产午夜久久久久| 亚洲激情第一页| 国产精品三级久久久久久电影| 久久综合一区| 国产精品久久国产愉拍| 免费在线播放第一区高清av| 欧美日韩精品国产| 老**午夜毛片一区二区三区| 欧美日韩国产一中文字不卡| 欧美专区在线观看一区| 免费在线亚洲| 久久国产精彩视频| 欧美黑人在线观看| 久久免费视频这里只有精品| 欧美日韩国产在线播放| 久久综合一区二区三区| 欧美日韩专区在线| 欧美成人午夜激情| 国产区日韩欧美| av成人动漫| 亚洲精品国产精品乱码不99按摩| 亚洲免费网站| 亚洲图片欧美午夜| 欧美黄色一级视频| 免费在线欧美黄色| 国产三区二区一区久久| 99视频在线精品国自产拍免费观看 | 国语对白精品一区二区| 国产精品99久久久久久www| 亚洲激情二区| 久久免费视频这里只有精品| 欧美一区二视频在线免费观看| 欧美日韩少妇| 亚洲精品国久久99热| 亚洲一区精彩视频| 久久夜色精品国产欧美乱极品| 午夜精品久久久久久| 欧美日韩精品在线播放| 亚洲福利电影| 亚洲电影一级黄| 久久影视精品| 欧美激情精品| 日韩亚洲在线| 欧美日韩你懂的| 一区二区高清| 香蕉久久一区二区不卡无毒影院 | 欧美日韩精品久久| 亚洲国产精品久久人人爱蜜臀| 国产一二精品视频| 久久成人免费电影| 久久一区二区三区四区五区| 狠狠色狠色综合曰曰| 久久精品国产免费观看| 久热re这里精品视频在线6| 国内外成人免费激情在线视频网站| 欧美一区中文字幕| 久色婷婷小香蕉久久| 亚洲韩国日本中文字幕| 欧美国产在线电影| 亚洲无毛电影| 久久久久一本一区二区青青蜜月| 国内一区二区在线视频观看| 久久亚洲精品一区| 亚洲欧洲免费视频| 亚洲欧美一区在线| 黑人极品videos精品欧美裸| 美女成人午夜| 亚洲手机在线| 欧美日本精品在线| 国产亚洲精品资源在线26u| 裸体女人亚洲精品一区| 欧美11—12娇小xxxx| 亚洲欧洲日产国码二区| 欧美三级欧美一级| 欧美一区二区大片| 亚洲福利精品| 午夜精品国产更新| 国产一区二区三区最好精华液| 久久久久看片| 日韩视频免费在线| 开元免费观看欧美电视剧网站| 在线观看视频一区二区| 欧美午夜一区| 久久在线精品| 中国成人黄色视屏| 欧美电影免费| 午夜亚洲伦理| 最新国产成人在线观看| 国产精品另类一区| 免费成人黄色片| 午夜精品久久久久久久99热浪潮| 欧美电影免费| 久久噜噜噜精品国产亚洲综合| 一本一本a久久| 在线精品国精品国产尤物884a| 国产精品第2页| 欧美国产日韩xxxxx| 欧美一区二区三区另类| 亚洲狼人综合| 欧美成年人视频网站欧美| 欧美在线播放| 亚洲一品av免费观看| 蜜臀av性久久久久蜜臀aⅴ四虎| 久久精品国产亚洲精品| 一本色道久久综合亚洲精品婷婷| 韩国女主播一区| 国产精品资源| 国产精品伦一区|