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

C小加

厚德 博學 求真 至善 The bright moon and breeze
posts - 145, comments - 195, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

KMP算法中關于next數組的探究

Posted on 2011-09-20 18:11 C小加 閱讀(5072) 評論(8)  編輯 收藏 引用 所屬分類: 數據結構和算法

從《嚴書》上看到了KMP算法,看了一遍沒懂,但覺得挺神奇的,就花費了幾天時間深入的理解。

算法的原理其實不難,難的就是那個巧妙的next數組,這個next數組很吸引我,我的大部分時間也都是花費在這個數組上面的。這個next數組是KMP里面一個很關鍵的地方,對于在數據結構書上看過一遍整個算法流程的人,能夠把next數組搞明白,整個KMP算法的整體思想就差不多理解了。然后在一些細節上面深入思考一下,就可以理解和領會改進的KMP算法。

 

一、KMP算法簡單介紹

KMP算法是字符串匹配算法的一種,相對于樸素的字符串匹配算法而言,可以大大避免重復遍歷的情況。此算法可以在On+m)的時間數量級上完成字符串匹配操作。

二、神奇的next數組

關于KMP算法的原理和實現,書上或者百度一下都可以找到,我在這里就不羅嗦那么多了,直接切入主題(next數組)。

我們設主串S=abcabcabca,模式串p=abcabx

KMP第一趟匹配:

                         i=6                    

S    :   a  b  c  a  b  c  a   b  c  a

位置 :  1  2  3  4  5  6  7  8  9  10

P    :   a  b   c  a  b  x

位置 :  1  2  3  4  5  6

                           j=6                      

第一次匹配到第6個位置的時候失敗了,按照樸素的算法,i要回溯到第2個位置,j要回溯到第1個位置重新匹配。KMP的話,主串中的i是不會回溯,模式串中的j回溯也不會回溯到第1個位置。注意這里是關鍵,i不用回溯就可以完成整個字符串的匹配。為什么i不需要回溯呢?我們先留下這個疑問。

我們把匹配成功的前5個字符研究一下。

1位置的前綴子串為:a , ab , abc , abca

5位置的后綴子串為:bcab , cab , ab , b

我們觀察發現兩組里面都有一個ab,你能看出點什么東西么,好的,先不管這個。

我們就按照樸素的算法來看,i回溯到第23位置都會在前5個字符中匹配失敗。

樸素匹配:

                   i=4                    

S    :  a  b  c  a  b  c  a   b  c  a

位置 : 1  2  3  4  5  6  7  8  9  10

P    :             a  b  c  a  b  x

位置 :            1  2  3  4  5  6

                   j=1 

當回溯到第4個位置的時候,成功匹配的字符為ab然后再去判斷S串的第6個字符和P串的第3個位置。這個然后我們先不管,觀察S中和P匹配的ab,在第一趟匹配的時候S中的ab是和P中前5個字符的最后兩個匹配的,而這一次匹配則是和P中前兩個字符匹配的。能發現點什么東西么?

不需要讓i回溯到之前的位置重新匹配,只需要找到在P串前5個字符中第一個位置的前綴子串和最后一個位置的后綴子串相等并且串長最大的那一對子串,讓j指向前綴子串最后一個字符的下一個位置3,和i所指向的6進行比較。往后遇見不匹配的時候采取和這個一樣的方法。

KMP第二趟匹配:

                           i=6                    

S    :   a  b  c  a  b  c  a   b  c  a

位置 :  1  2  3  4  5  6  7  8  9  10

P    :              a  b  c  a  b  x

位置 :             1  2  3  4  5  6

                           j=3 

這個時候就需要next數組的建立了,next[6]存儲的就是前5個字符組成的字符串中的第一個位置的前綴子串和最后一個位置的后綴子串相等并且串長最大的那一對子串的最后一個字符的下一個位置,也就是3,也就是和P串中第3個位置匹配。

寫到這里,next數組應該可以得出來了。

具體代碼怎么得出來的,書上面都有。。那個應該不難。

對于next數組還有一個優化,《嚴書》上講的很清晰。

三、next數組在ACM中的應用

直接用KMP算法真的去匹配兩個字符串其實很少見,除非字符串里的字符集范圍很小,或字符重復數量過多,用KMP可大減少時間,否則一般都是直接樸素匹配。
kmp
算法在ACM中并不大可能用來直接用,主要有用的是對它的理解和它的精華部分---- next數組,這個的一個用途就是確定重復子串,具體參見 poj2406,poj1961,poj2752。

next數組模板

 

Feedback

# re: KMP算法中關于next數組的探究  回復  更多評論   

2011-09-21 12:38 by ooseven
正則表達式算法現在已經很成熟了,并且DFA方式的正則引擎同樣不需要回溯,而且通用性高很多,個人認為沒有必要糾結與kmp,實際應用中根本不需要,用dfa正則引擎好用得多,效率也不差。可能就是內存占用稍微高了點。當然,現在很多人研究kmp只是因為考試需要而已。

# re: KMP算法中關于next數組的探究  回復  更多評論   

2011-09-22 09:00 by C小加
@ooseven
我研究kmp是因為興趣,算法的用處雖然不大,但是思想卻是很吸引人的。正則表達式算法我還沒接觸過,不過看起來也蠻吸引人的。

# re: KMP算法中關于next數組的探究  回復  更多評論   

2011-09-22 11:35 by ooseven
@C小加
正則表達式算法看似簡單,但是,動手實踐之后你就會發現,要徹底研究透根本就是個無底洞,復雜度主要與狀態數的優化。因此,我的策略是能手工寫出一個正則引擎就可以了,適可而止!

# re: KMP算法中關于next數組的探究  回復  更多評論   

2011-09-22 16:47 by C小加
@ooseven
這樣啊,我想研究一下,不知道怎么才能和大牛進一步交流呢?如果有問題的話想請教一下。

# re: KMP算法中關于next數組的探究  回復  更多評論   

2011-09-22 17:32 by ooseven
@C小加
哈,大牛可不敢當,正則表達式算法屬于編譯原理里的一門功課,而編譯原理在cppblog里唯一的大牛是 陳梓瀚(vczh),我的那個正則引擎在實現的時候還請教過他呢。

# re: KMP算法中關于next數組的探究  回復  更多評論   

2011-09-22 17:49 by C小加
@ooseven
恩恩。看到了。那兩篇文章。還有你的評論。嘻嘻。。那位大牛應該正在寫編譯器吧,而且感覺他對圖形圖像也很有研究,厲害呀。先拜讀那兩篇文章吧。

# re: KMP算法中關于next數組的探究  回復  更多評論   

2011-11-03 21:46 by 淺笑
球球。。。

# re: KMP算法中關于next數組的探究  回復  更多評論   

2013-10-12 11:00 by 周炎婷
問一下,神馬叫第一個位置的前綴子串?
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品久久久久毛片软件 | a91a精品视频在线观看| 久久精品综合| 久久免费国产精品1| 久久综合九色综合欧美就去吻| 久久久久综合一区二区三区| 久久精品中文字幕一区二区三区| 久久夜色精品国产欧美乱| 久久人人爽人人爽| 欧美国产日本在线| 亚洲精品中文字幕女同| 亚洲视频电影图片偷拍一区| 亚洲女优在线| 久热精品在线视频| 欧美日韩精品一本二本三本| 欧美午夜精品久久久久免费视 | 国产精品免费区二区三区观看| 国产日产亚洲精品| 亚洲福利在线视频| 日韩一级成人av| 久久国产欧美日韩精品| 欧美国产日韩一二三区| 中文久久精品| 麻豆国产精品777777在线| 欧美区日韩区| 国产综合色在线| 亚洲免费av片| 久久久91精品国产| 日韩视频在线一区二区| 欧美在线视频日韩| 中文av字幕一区| 欧美激情女人20p| 久久av一区二区三区| 久久成人资源| 亚洲精品国产精品久久清纯直播| 亚洲精品日韩精品| 久久成人av少妇免费| 欧美激情2020午夜免费观看| 欧美日韩一区在线观看视频| 午夜免费电影一区在线观看 | 正在播放亚洲| 快射av在线播放一区| 亚洲一区二区免费看| 欧美a级一区| 国产一区二区精品久久91| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美一级视频免费在线观看| 欧美人在线观看| 国产亚洲欧美日韩精品| 亚洲一区二区三区涩| 欧美黄网免费在线观看| 久久精品中文| 国产真实精品久久二三区| 性欧美暴力猛交69hd| 一区二区三区三区在线| 欧美日韩亚洲国产精品| 日韩午夜在线观看视频| 欧美成人性生活| 久久久久一区二区| 尤物网精品视频| 久久女同精品一区二区| 性高湖久久久久久久久| 国产精品美女久久久久久2018| 亚洲欧美另类久久久精品2019| 欧美中日韩免费视频| 午夜精彩视频在线观看不卡| 欧美人牲a欧美精品| 亚洲人成毛片在线播放| 欧美成人国产一区二区| 久久久精品2019中文字幕神马| 韩国精品久久久999| 欧美一区三区二区在线观看| 夜夜嗨av一区二区三区| 欧美va亚洲va日韩∨a综合色| 亚洲第一精品夜夜躁人人爽| 猛男gaygay欧美视频| 免费美女久久99| 亚洲福利视频一区二区| 亚洲国产成人久久综合一区| 欧美成年人视频网站欧美| 日韩一级片网址| 亚洲精品久久| 亚洲黄色小视频| 日韩视频在线免费观看| 亚洲视屏在线播放| 一二三四社区欧美黄| 国产精品jizz在线观看美国 | 亚洲激情成人在线| 欧美日韩国产成人在线91| 午夜精品成人在线视频| 亚洲深夜福利在线| 欧美一级专区| 久久一区二区三区四区| 久久精品av麻豆的观看方式| 欧美在线亚洲综合一区| 黄色一区二区三区四区| 亚洲成人在线视频播放 | 亚洲精品美女在线观看| 亚洲欧洲精品一区二区精品久久久| 国产精品播放| 欧美96在线丨欧| 国产精品久久97| 你懂的视频欧美| 国产精品嫩草影院一区二区| 欧美国产日韩在线| 国产精品稀缺呦系列在线| 亚洲国产精品黑人久久久| 国产欧美一区二区三区久久人妖| 欧美成人dvd在线视频| 欧美日韩国产亚洲一区| 蜜桃av一区二区| 国产精品网曝门| 亚洲精品国产欧美| 国内精品久久久久影院色 | 一区二区三区久久| 久久人体大胆视频| 欧美一区二区视频97| 欧美激情自拍| 久久亚洲不卡| 国产精品欧美一区二区三区奶水| 亚洲韩日在线| 亚洲国产精品久久精品怡红院| 亚洲欧美日韩中文视频| 亚洲永久免费精品| 欧美日韩精品是欧美日韩精品| 亚洲国产高潮在线观看| 一区二区三区在线免费视频| 欧美一级在线亚洲天堂| 欧美专区在线播放| 国产精品自拍在线| 999在线观看精品免费不卡网站| 在线成人欧美| 久久免费视频网| 欧美成人中文字幕| 亚洲高清影视| 狼狼综合久久久久综合网| 久久久久久久久久久一区 | 亚洲激情影视| 久久手机免费观看| 欧美成人一区二区在线| 亚洲成人资源| 蘑菇福利视频一区播放| 亚洲福利久久| 日韩午夜高潮| 欧美视频在线观看一区二区| 国产一区二区精品| 亚洲国产成人精品久久久国产成人一区 | 欧美婷婷久久| 亚洲少妇一区| 欧美一区二区精品| 国产亚洲成av人片在线观看桃| 午夜精品视频一区| 久久久无码精品亚洲日韩按摩| 国外成人在线视频| 老牛嫩草一区二区三区日本| 亚洲风情亚aⅴ在线发布| 亚洲最新视频在线| 国产精品久久久久久久久动漫| 中国女人久久久| 久久成人免费日本黄色| 好吊色欧美一区二区三区四区| 老司机午夜精品视频| 亚洲电影免费观看高清| 亚洲无吗在线| 欧美色大人视频| 性欧美暴力猛交另类hd| 麻豆国产精品va在线观看不卡| 另类成人小视频在线| 亚洲欧美综合国产精品一区| 久久国产精品久久国产精品| 国产精品高潮呻吟久久av无限| 99re6这里只有精品| 西西裸体人体做爰大胆久久久| 国产日韩在线一区二区三区| 久久综合九色综合欧美狠狠| 日韩小视频在线观看| 久久久久久久高潮| 99国产精品久久| 国产午夜精品久久久久久免费视| 噜噜噜噜噜久久久久久91| 日韩亚洲欧美高清| 久热国产精品| 亚洲视频精选在线| 激情成人av| 国产精品乱人伦一区二区| 你懂的视频一区二区| 亚洲精品国久久99热| 欧美一区二区视频97| 日韩一区二区电影网| 亚洲一区二区av电影| 香港久久久电影| 欧美高潮视频| 久久亚洲综合网| 欧美色一级片| 久久日韩粉嫩一区二区三区| 亚洲人午夜精品免费| 久久亚洲国产成人| 亚洲欧美日韩专区| 一区二区在线视频观看| 国产精品久久久久91|