亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

KMP算法(學習記錄)

2019-11-10 18:11:14
字體:
來源:轉載
供稿:網友

KMP算法之前感覺已經理解了,但過了一段時間,感覺又不知是什么,現在重新學習下,做下記錄。

目的:匹配字符串遇到不匹配的時候不用回溯,而是通過一個數組(next[]/nextval[])確定主串不匹配字符接下來和匹配串哪個位置的字符進行比較。(假設位置都從0開始) 匹配過程 此時匹配到6位置,發現不匹配

這里寫圖片描述匹配串滑動盡可能的遠的距離

實際上是找到匹配串不匹配位置(6)前的字符串即abadab前綴串和后綴串的最大公共部分的位置

這里寫圖片描述 可以看出,abadab的最大公共部分是ab,所以主串位置6的字符d需要和匹配串位置1后面的字符a比較

繼續比較字符的位置=前綴后綴串最大公共部分的長度(ab的長度為2,b的位置是2-1,b后面字符的位置為2-1+1=2)

現在求數組next[],設匹配串是s[0…n] next[0]=-1,-1代表主串某字符和匹配串第一個字符匹配失敗 next[1]=0 , 一個字符的沒有前綴和后綴,其長度為0 假設next[i] = x ,即匹配串0到j-1前后綴的最大公共部分是0到x-1,此時串的狀態見圖 這里寫圖片描述

現在求next[i+1],即求0到i前后綴的最大公共部分,其組成必定是下圖這樣的,相當于求 位置0到i-1字符串的前后綴的公共部分 && s[i]==s[?]成立的最大長度

這里寫圖片描述

當位置i和位置x的字符相等時,顯然?=x,最大公共部分長度為x+1, 當位置i和位置x的字符不相等時,即長度為x的公共串不符合要求,需要取相對小些的公共部分,這個肯定也是0到x-1的前后綴最大公共部分,即next[x],此時next[i]和next[?](此時?=next[x])進行比較,不相等表示還要取更小的公共部分(即0到next[x]-1的前后綴最大公共部分),重復這個過程,直至s[i]==s[?]或者?==-1為止,-1代表找不到公共部分,即next[i]=0

// 輸入s[0...n] 空數組next[0...n] 求next[] int i=0,x=-1; next[i]=x; while(i<=n) { if(x==-1 || s[i]==s[x]) next[++i]=++x; else x=next[x]; }

現在發現個問題,比如next[i]=x,表示的是主串與匹配串匹配是在匹配串的位置i處發現不匹配,然后匹配串盡量右移,使主串的那個字符與匹配串的位置x的字符進行比較,如果匹配串位置x的字符和位置i的字符一樣呢,肯定又是不匹配,主串字符再與匹配串位置next[x]的字符進行匹配,這不是浪費次數嘛 這里寫圖片描述

現在可以改進一下數組next,即當s[i]和s[next[i]]一樣時,next[i]=next[next[i]],這個就是nextval[]數組

這里寫圖片描述

// 輸入s[0...n] 空數組nextval[0...n] 求nextval[] int i=0,x=-1; nextval[i]=x; while(i<=n) { if(x==-1 || s[i]==s[x]) { ++i;++x; if(s[i]==s[x]) nextval[i]=nextval[x];//增加一個判斷即可 else nextval[i]=x; } else x=next[x]; }

KMP函數

//輸入str[0...size] s[0....n] int i=0;j=0; while[i<=size && j<=n] { if(j==-1 || str[i]==s[j]){++i;++j;} else j=nextval[j]; } if(j>n) return i-n-1;//匹配成功 else return -1; //匹配失敗

這里寫圖片描述


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久999精品免费| 久久久欧美精品| 国产日韩欧美黄色| 久久精品电影一区二区| 亚洲精品美女在线观看| 国产精品国内视频| 国产精品99久久99久久久二8| 欧美黑人一区二区三区| 92版电视剧仙鹤神针在线观看| 欧美性一区二区三区| 欧美亚洲在线视频| 亚洲视频免费一区| 亚洲欧美另类人妖| 成人在线视频网| 亚洲第一级黄色片| 国产亚洲欧美另类中文| 亚洲国产精品va在看黑人| 精品日本美女福利在线观看| 欧美老妇交乱视频| 日韩有码在线视频| 欧美在线日韩在线| 中国人与牲禽动交精品| 91视频国产高清| 久久精品国产91精品亚洲| 国产精品男女猛烈高潮激情| 国内精品久久久久久久久| 欧美性猛交xxxx富婆弯腰| 国产成人拍精品视频午夜网站| 播播国产欧美激情| 国产第一区电影| 欧美另类交人妖| 欧美激情国内偷拍| 欧美性xxxx18| 欧美激情精品久久久久久| 国产一区二区香蕉| 久久久久亚洲精品| 欧美日韩色婷婷| 欧美性猛交xxxx乱大交蜜桃| 日本精品视频在线观看| 亚洲a级在线观看| 精品二区三区线观看| 亚洲成人久久一区| 欧美日韩成人在线播放| 91免费在线视频网站| 久久精品视频在线观看| 欧美日韩在线视频一区| 欧美精品国产精品日韩精品| 久久青草精品视频免费观看| 国产美女久久精品香蕉69| 欧洲亚洲妇女av| 久久亚洲欧美日韩精品专区| 亚洲人成网站免费播放| 欧美孕妇孕交黑巨大网站| 精品国产精品三级精品av网址| 欧美日韩在线视频一区| 亚洲福利视频免费观看| 亚洲女人被黑人巨大进入al| 国产精品成人一区二区三区吃奶| 91精品国产色综合久久不卡98| 亚洲欧洲第一视频| 欧美最猛性xxxxx免费| 伊人激情综合网| 亚洲理论在线a中文字幕| 成人黄色av网| 精品国产老师黑色丝袜高跟鞋| 日韩综合视频在线观看| 亚洲丝袜av一区| 国产亚洲欧美日韩一区二区| 亚洲欧美制服第一页| 亚洲国产成人久久综合一区| 久久精品国产亚洲一区二区| 久久久久女教师免费一区| 色妞色视频一区二区三区四区| 欧美精品精品精品精品免费| 亚洲国产成人精品女人久久久| 国产美女精品视频免费观看| 亚洲xxx自由成熟| 正在播放欧美视频| 欧美视频免费在线观看| 国产精品久久一| 亚洲人成电影网站色www| 日韩av第一页| 国产成人精品视频在线| 欧美激情视频在线免费观看 欧美视频免费一| 丝袜一区二区三区| 中文字幕亚洲欧美日韩2019| 国产精品自在线| 精品一区二区电影| 97精品久久久中文字幕免费| 亚洲精品美女在线观看| 欧美性生交xxxxx久久久| 97国产精品久久| 91久久精品国产91久久性色| 欧美日韩精品在线播放| 久久久免费高清电视剧观看| 国内精品久久久久| 久久九九热免费视频| 欧美一级淫片丝袜脚交| 国产精品第1页| 国产在线久久久| 欧美亚洲伦理www| 日本欧美国产在线| 91精品国产自产在线观看永久| 91黄色8090| 国产成人免费av| 精品久久久久久久久久久久久久| 亚洲国产精品资源| 国产午夜精品一区理论片飘花| 国产婷婷97碰碰久久人人蜜臀| 日韩国产欧美区| 国产999在线| 欧美午夜精品久久久久久久| 久久99精品久久久久久青青91| 成人xxxx视频| 欧美高清视频在线| 国产视频精品在线| 久久中文精品视频| 一区二区三区 在线观看视| 97超视频免费观看| 一区二区三区国产视频| 日韩在线观看免费网站| 久久久精品国产亚洲| 成人精品一区二区三区| www.亚洲免费视频| 久久久精品免费| 69久久夜色精品国产69乱青草| 日韩精品视频在线观看免费| 欧美性猛交xxxx乱大交蜜桃| 亚洲欧美中文日韩v在线观看| 一区二区三区四区精品| 国产成人精品在线| 久久精品视频免费播放| 国产亚洲精品美女久久久久| 国精产品一区一区三区有限在线| 91精品国产综合久久香蕉922| 国产亚洲a∨片在线观看| 爽爽爽爽爽爽爽成人免费观看| 久久亚洲国产成人| 欧美日韩国产精品一区二区不卡中文| 综合网日日天干夜夜久久| 国产一区二区三区在线观看网站| 欧美亚洲国产精品| 成人欧美一区二区三区黑人| 久久天天躁狠狠躁夜夜躁2014| 国产suv精品一区二区三区88区| 国产精品一区久久久| 成人性生交xxxxx网站| 亚洲精品美女视频| 国产精品男人爽免费视频1| 国产成人鲁鲁免费视频a| 欧美三级xxx| 国产精品老女人精品视频| 国自产精品手机在线观看视频| 精品国产成人在线| 国产成人福利视频| 欧美黑人xxxⅹ高潮交| 色偷偷91综合久久噜噜| 91av在线播放| 影音先锋日韩有码| 欧美精品videos另类日本| 国产精品一区二区三区免费视频| 中文字幕国产日韩| 亚洲经典中文字幕| 亚洲天堂精品在线|