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

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

KMP算法(學習記錄)

2019-11-10 20:49:39
字體:
來源:轉載
供稿:網友

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
亚洲一区亚洲二区亚洲三区| 久久精品亚洲热| 国产suv精品一区二区三区88区| 亚洲人精选亚洲人成在线| 美女黄色丝袜一区| 性日韩欧美在线视频| 欧美壮男野外gaytube| 日韩在线观看免费网站| 亚洲黄色av女优在线观看| 亚洲高清不卡av| 亚洲精品电影网在线观看| 久久国产一区二区三区| 亚洲人成网站在线播| 欧美成人性色生活仑片| 中文字幕亚洲字幕| 日韩欧美在线观看| 最好看的2019的中文字幕视频| 国产精品视频在线观看| 成人久久18免费网站图片| 国产精品视频99| 成人一区二区电影| 91在线观看免费观看| 国产欧美一区二区三区视频| 亚洲国产免费av| 亚洲色在线视频| 国模精品视频一区二区三区| 国产免费一区二区三区在线观看| 亚洲色图狂野欧美| 亚洲午夜精品久久久久久性色| 91老司机在线| 国产69久久精品成人看| 91国内产香蕉| 久久久人成影片一区二区三区| 亚洲成人黄色网| 欧美激情精品久久久久久| 成人精品久久一区二区三区| 久久免费观看视频| 亚洲欧美国产日韩中文字幕| 精品女同一区二区三区在线播放| 日本成人在线视频网址| 亚洲精品午夜精品| 91最新国产视频| 国产欧美va欧美va香蕉在| 国产日韩在线精品av| 亚洲网在线观看| 亚洲精品视频中文字幕| 国产成人av在线| 久久亚洲精品国产亚洲老地址| 国产日韩av高清| 国产精品久久97| 高跟丝袜欧美一区| 亚洲国产天堂久久综合| 欧美日韩国产限制| 日韩精品极品在线观看播放免费视频| 亚洲人成欧美中文字幕| 正在播放国产一区| www高清在线视频日韩欧美| 亚洲字幕在线观看| 亚洲欧美视频在线| 日韩欧美精品网址| 欧美日韩一区二区免费视频| 搡老女人一区二区三区视频tv| 欧美福利视频在线| 九九热最新视频//这里只有精品| 亚洲人成亚洲人成在线观看| 欧美在线视频观看免费网站| 久久国产精品亚洲| 亚洲精品99久久久久| 亚洲va欧美va国产综合久久| 2023亚洲男人天堂| 欧美亚洲第一页| 日韩精品在线免费播放| 热99精品里视频精品| 日韩中文字幕在线视频播放| 浅井舞香一区二区| 国产+成+人+亚洲欧洲| 国产精品亚洲片夜色在线| 亚洲国产精品推荐| 欧美巨猛xxxx猛交黑人97人| 国产精品三级久久久久久电影| 久久久日本电影| 一本色道久久综合狠狠躁篇怎么玩| 久久久久久高潮国产精品视| 久久露脸国产精品| 久久久久久久久久久免费精品| 亚洲最大福利网站| 91色视频在线观看| 亚洲第一免费网站| 8x拔播拔播x8国产精品| 日韩欧美国产中文字幕| 法国裸体一区二区| 日韩在线激情视频| 国产精品一区二区三| 欧美另类极品videosbestfree| 日韩精品中文字| 国外成人性视频| 日韩在线观看精品| 亚洲福利在线看| 国产精品jvid在线观看蜜臀| 久久久久久久一区二区| 亚洲美女中文字幕| 日本精品久久久久久久| 久久亚洲精品视频| 亚洲色图欧美制服丝袜另类第一页| 国产在线观看91精品一区| 亚洲第一页在线| 亚洲最大av在线| 欧洲精品毛片网站| 欧美激情国产精品| 欧美亚洲视频在线观看| 国产精品久久久久久久av电影| 久热爱精品视频线路一| 国产日韩av高清| 岛国av一区二区| 日韩av不卡电影| 亚洲第一精品电影| 欧美伊久线香蕉线新在线| 欧美激情视频一区二区三区不卡| 国内精久久久久久久久久人| 国产精品啪视频| 黑人巨大精品欧美一区二区免费| 欧洲成人在线视频| 秋霞av国产精品一区| 亚洲奶大毛多的老太婆| 欧洲美女7788成人免费视频| 色偷偷88888欧美精品久久久| 在线性视频日韩欧美| 国产精品久久综合av爱欲tv| 中文欧美日本在线资源| 成人伊人精品色xxxx视频| 欧美一区在线直播| 亚洲最大福利视频网| 久久久国产影院| 91精品国产自产91精品| 91热福利电影| 国产精品偷伦免费视频观看的| 在线观看日韩欧美| 久热精品视频在线观看| 亚洲国产精品人久久电影| 中文字幕亚洲激情| 亚洲精品福利在线| 亚洲欧美精品一区二区| 亚洲一区二区久久| 国产精品视频内| 欧洲成人午夜免费大片| 久久91亚洲精品中文字幕奶水| 久热99视频在线观看| 国产mv免费观看入口亚洲| 欧美激情免费视频| 全亚洲最色的网站在线观看| 性日韩欧美在线视频| 欧美大片免费看| 日韩免费看的电影电视剧大全| 亚洲精品ady| 美日韩丰满少妇在线观看| 中文字幕欧美日韩在线| 亚洲国产古装精品网站| 91精品国产高清久久久久久| 久久激情视频免费观看| 国产午夜精品美女视频明星a级| 成人情趣片在线观看免费| 精品亚洲国产视频| 欧美野外wwwxxx| 成人激情电影一区二区|