AC自动机 - 关于Fail指针
fail指針可以說是AC自動機里最難理解的東西,怎樣更好的理解AC自動機的fail指針?
先來看一幅圖:
看這幅圖上的fail指針是怎么構造的.
樹上的詞分別是:
{ he , hers , his , she}
按圖所示分成3層??吹降谌龑?#xff0c;是"she",其中:
①s指向root
②h先找到s的fail指針
發現是0號指針,不是h,然后h就不高興了,再問問s的fail指針root:“你有沒有兒子和我同名叫h的”
root說:“有,你指向他吧”,然后h就高興的指向了第一行的h.
③e開始找了,首先問他老爸h:“你的fail指針指著誰”
h說:“圖上第一行那個h啊”
然后e就屁顛屁顛地跑去問圖上第一行那個h:“你有沒有名字和我一樣的兒子啊”
圖上第一行那個h說:“有,他地址是xxx”
最后e的fail指針就指向xxx地址,也就是第一行那個e了
發現這樣,如果一個字符串查到第三行的e以后的字符才不匹配,那說明他前面應該有個‘he’
剛好e的失敗指針指向的是第一行的‘he...’的那個e;
這樣就不用從h開始再找一遍,而是接著第一行的e繼續往后找,從而節省了時間.
--------------------------------------------------------- End.
轉載請注明:http://www.cnblogs.com/crazyacking/p/4659501.html?
轉載于:https://www.cnblogs.com/crazyacking/p/4659501.html
總結
以上是生活随笔為你收集整理的AC自动机 - 关于Fail指针的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C#中的泛型化方法的实现
- 下一篇: Android环境配置