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

冬天¤不回來
海風輕輕吹過我的臉龐 陽光溫柔的灑在我身上 海鷗自由的飛在天空中像 快樂的徘徊在游樂場 白云在偷看彩虹的模樣 海洋總為那船長指方向 海浪撫摸著沙灘的衣裳 我也每天都為他換上新裝 找到方向 揭開迷茫 學著堅強 努力去闖!
posts - 20,  comments - 90,  trackbacks - 0

???????????? KMP 匹配算法是由 "Knuth? Morris? Pratt"? 提出的一種快速的模式匹配算法. ()


1.待解決的問題: 假設P為給定的子串,T是待查找的字符串,要求從T中找出與P相同的所有子串,這稱為模式匹配問題. (可以給出子串在T中的位置) (下文中提
到的PT分別為子串和目標串)

讓我們先來看個例題:

T:???t0??????t1?????t2??????t3?.... tm-1 ... tn-1

P:???p0????? p1???? p2??????p3 .....pm-1??????????
???????????????????????????????????????????????

T的最左邊開始比較,使得 TK = PK? , 則匹配成功


2.解決模式匹配問題的方案:

A:?
樸素的模式匹配算法(思路簡單,但不夠簡便時間長 有回溯) : 最簡單和最直接的做法.P中的字符依次與T中的字符進行比較 遇到不相等的字符,則可將P右移一個字符,從新進行比較,直到某次匹配成功或者到達P的最右字符移出T為止.

: P="aaaba", T="aaabbaaaba", 則匹配過程如下圖

?T:???? a???a???a???b???b???a???a???a?? b? a
?P:?????a???a???a???b???a?????????????????????????????????????????????????????????????????

????????????a???a???a???b???a?????????????????
??????????????????????????????? .....
??????????????????????????? a???a???a???b? a????????????

從上不難分析,最壞的情況是"每次比較都在最后一個字符出現不等,每趟最多比較M,最多比較N-M+1,總的比較次數最多為M*(N-M+1)" ,時間復雜性為0(M*N).?P右移一位時,不管上一趟比較的中間結果是什么,因此回溯是不可避免的(: 3aaa 不需要一位一位的移?)?.下面我來介紹無回溯的KMP算法.


3.KMP
算法解決匹配中哪些主要問題:?
A.
當字符串比較出現不等時,確定下一趟比較前 應該將P右移多少個字符;?
B. P
右移后,應該從哪個字符開始和T中剛才比較時不等的那個字符繼續開始比較.

???
我們通過樸素模式匹配的例子來引出問題. 在第一次比較過程中失敗的是P的第4個字符b,這表明P的前4個字符是成功的.模式P的第3個字符b在它的前3個字符(aaa)中并未出現.因此,在下一次比較時候,至少要將P向后移4個字符; 再看P的第一個字符與最后一個字符是相同的因此將P右移4個字符后 再從第一個字符比較 可定也是不等的.? 綜上所訴:應該將P右移5個字符 再從P的第0個字符和T的第5個字符開始比較!

KMP
算法核心: KMP算法借助于一個輔助數組next來確定當匹配過程中出現不等時,模式P右移的位置和開始比較的位置.next[i]的取值只與模式P本身的前i+1項有關,而與目標T無關.???? 匹配過程中遇到Pi不等于Tj,next[i]>=0,則應將P右移i-next[i]位個字符,P中的第next[i]個字符與Tj 進行比較;:next[i]= -1,P中的任何字符都不必再與Tj比較,而應將P右移i+1個字符,P0Tj+1從新開始下一輪比較(可能不太好理解,自己找個例子,對著話一句一句試試看)
?
?
因此只要計算出與模式P相關的next數組,按上面的含義,就可以很容易地給出串的匹配算法.(問題就這樣轉化了)

?C.next
的計算:? P = " 01001010100001"為例.

??i???:????????????0?? 1???2?? 3???4???5???6????.....??
? P?? :????????????0???1???0???0???1???0?? 1????.....

?j(next[i]) :?????-1???0???0?? 1?? 1?? 2???3????.....

修正(next[i])??:? -1???0??-1???1???0??-1???3????.....
例子中的j(next[i])為未修正前的next數組(關于修正我會在下次提到).
1:我們要算next[2]的值,有關的為P本身的前2個字符0,1.?? 在字符串01,尋找出?? "左右相同的最大字符串,此字符串所含字符的個數就為next[i]的值"0不等于1,相同字符串不存在,所以next[i] = 0;

2:我們要算next[6]的值,有關的為P本身前6個字符010010? 此字符串中010 = 010
左右相同的最大字符串為010,個數為3.所以next[i]=3;

3:我們要算next[5]的值,有關的為P本身前5個字符01001 此字符串中 01=01 左右相同的最大字符串為01,個數為2.所以next[i]=2;


通過上面的例子大家應該有所了解了,有什么問題可以留言給我.

???????????????????????

?????????????
???????????? KMP
的算法???? VC++6.0

?

Cmystring::GenKMPNext(int *next, CMyString *s)

{ int i=0; j=-1;

?? next[0]=-1;

?while(i<s->length)

? {

? while(j>=0&&s->str[i]!=s->str[j])

???? j=next[j];

?? i++;j++;

?? if(s->str[i]==s->str[j])

????? next[i]=next[j];
? else? next[i]=j;}

}


///////////////////
串類的find()方法 KMP匹配算法////////////////////////
int CMyString::find(const CMyString *S)
{
??? int i , j , *next = new int[s->length];
??? GenKMPNext(next, s);
????for(i=?0,j=0;i< s->length&&j<length;)
????{
????????if( s->str[i] = =str[j] ) { i++ , j++;}
??????? else
??????????? if(next[i] >=0)
?????????????????i =?next[i];
????????????else
??????????? { i = 0; j++}
?????}
???? if(i>= s->length)
?????? return? j - s->length;
???? else
????????? return -1;
}


????????????????

posted on 2006-10-10 21:58 冬天¤不回來 閱讀(11383) 評論(15)  編輯 收藏 引用

FeedBack:
# re: KMP算法初學
2006-10-10 22:03 | 冬天¤不回來
今天真是郁悶,一下課就回來開門造車,寫KMP,花了3個小時寫了個很好的,結果一發表出去 卻變成一堆亂78糟的東西!!可能是因為顏色 下標 大小寫等搞混淆了! 然后又花了40分鐘,刪的刪,改的改,最后出來這個讓我無語的版本.痛苦ED.
雖然刪了些,但精華還在,希望對大家有幫助.  回復  更多評論
  
# re: KMP算法初學
2006-12-29 22:06 | lily1115
沒有啊!很有特色!  回復  更多評論
  
# re: KMP算法初學
2007-01-04 20:30 | pengkuny
博主,能不能換個模板?
看著實在難受  回復  更多評論
  
# re: KMP算法初學
2007-04-14 16:03 | hotjuly
@冬天&#164;不回來
今天真是郁悶,一下課就回來開門造車,寫KMP,花了3個小時寫了個很好的,結果一發表出去 卻變成一堆亂78糟的東西!!可能是因為顏色 下標 大小寫等搞混淆了! 然后又花了40分鐘,刪的刪,改的改,最后出來這個讓我無語的版本.痛苦ED.
====================================================================
誒,這個排版。。。
夠郁悶的,精神可嘉。
樓主可以在word中全部搞定,然后轉換成html的,然后從html全部復制到blog上,這樣排版應該沒問題了。比較重要的文章可以轉換成pdf,提供下載,可以讓讀者線下瀏覽。www.51files.com 不錯的
btw:你們一幫人都在搞算法,什么專業的?  回復  更多評論
  
# re: KMP算法初學
2008-10-10 20:23 | yjw
寫得太好了   回復  更多評論
  
# re: KMP算法初學
2008-12-05 11:57 | hf
寫的確實不錯啊!!  回復  更多評論
  
# re: KMP算法初學[未登錄]
2009-09-30 08:37 | 123
有錯誤  回復  更多評論
  
# re: KMP算法初學
2011-09-02 21:51 | ROSALINDA19Wolfe
People deserve good life and <a href="http://bestfinance-blog.com/topics/personal-loans">personal loans</a> or auto loan can make it better. Just because freedom bases on money.   回復  更多評論
  
# re: KMP算法初學
2011-11-03 16:57 | nono
@冬天&#164;不回來
思想還是錯了..  回復  更多評論
  
# re: KMP算法初學
2015-09-10 15:15 | taruhan bola;judi bola;agen bola;sbobet;judi onlin
For instance, coffee shops have menus of brown color or shades of the same hue in order to bring the atmosphere of the cafe and set it in the menu. Whereas, a Japanese or Chinese restaurant would make a more colorful menu that uses images that reflect their culture and their food – since their dishes include various colors. This blog will be showing you some of the most amazing menu designs for your use.I seriously appreciate people like you! Take care!!;)!!visit my site and Play  回復  更多評論
  
# re: KMP算法初學
2015-09-10 15:16 | taruhan bola;judi bola;agen bola;sbobet;judi onlin
The you have is very useful. The sites you have referred was good. Thanks for sharing....  回復  更多評論
  
# re: KMP算法初學
2015-09-10 15:17 | taruhan bola;judi bola;agen bola;sbobet;judi onlin
I really appreciate the kind of topics post here. Thanks for sharing us a great information that is actually helpful. Good day! nirmala.cutez@yahoo.com  回復  更多評論
  
# re: KMP算法初學
2015-09-10 15:18 | nagapoker;poker online;game poker:poker indonesia;
This is a very good post. Just wonderful. Truly, I am amazed at what informative things you've told us today  回復  更多評論
  

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


QQ:41696402

<2007年3月>
25262728123
45678910
11121314151617
18192021222324
25262728293031
1234567

常用鏈接

留言簿(3)

隨筆檔案

文章檔案

Programming

最新隨筆

搜索

  •  

積分與排名

  • 積分 - 40059
  • 排名 - 542

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            玖玖玖国产精品| 欧美日韩国产999| 久久精视频免费在线久久完整在线看 | 在线观看视频一区二区| 亚洲视屏在线播放| 亚洲福利视频一区二区| 性色av一区二区怡红| 欧美日韩亚洲视频| 亚洲国产精品一区二区第一页| 欧美一级免费视频| 亚洲一区在线观看免费观看电影高清| 欧美黄色成人网| 亚洲人精品午夜| 亚洲第一精品夜夜躁人人爽| 久久国产福利| 韩国视频理论视频久久| 久久精品女人天堂| 欧美一区二视频在线免费观看| 国产精品vip| 亚洲中字在线| 亚洲一区在线免费| 国产情人节一区| 久久久久高清| 久久国产精品久久久久久电车| 国产精品永久免费在线| 久久精品一区蜜桃臀影院| 欧美一级网站| 国产资源精品在线观看| 蜜臀va亚洲va欧美va天堂| 久久综合五月天婷婷伊人| 亚洲国产美女精品久久久久∴| 免费不卡欧美自拍视频| 久久尤物视频| 亚洲欧洲一区二区天堂久久| 亚洲狠狠丁香婷婷综合久久久| 欧美黄色大片网站| 亚洲欧美日韩精品综合在线观看| 亚洲一区二区四区| 激情六月综合| 亚洲人成网站精品片在线观看| 欧美色大人视频| 欧美亚洲免费| 久久一区中文字幕| 亚洲午夜激情免费视频| 午夜免费日韩视频| 一区二区三区偷拍| 亚洲欧洲精品一区二区精品久久久 | 亚洲影院色无极综合| 午夜电影亚洲| 在线电影国产精品| 亚洲精品一区在线观看香蕉| 国产精品久久久久久妇女6080 | 久久久天天操| 欧美www视频在线观看| 亚洲一级二级| 久久久精品免费视频| aa成人免费视频| 欧美亚洲日本网站| 一本久道久久综合狠狠爱| 亚洲综合色视频| 亚洲二区在线视频| 亚洲香蕉伊综合在人在线视看| 极品尤物av久久免费看| 一区二区三区精品| 在线观看视频免费一区二区三区| 一区二区三区久久精品| 在线电影欧美日韩一区二区私密| 一本一道久久综合狠狠老精东影业| 国产一区二区毛片| 一本色道久久99精品综合| 亚洲国产清纯| 欧美一区二区日韩一区二区| 99视频精品全国免费| 久久天堂精品| 小嫩嫩精品导航| 欧美三级第一页| 亚洲国产精品久久| 有码中文亚洲精品| 欧美一区三区二区在线观看| 中文精品视频| 免费人成精品欧美精品| 老司机免费视频一区二区| 国产精品试看| 一本大道久久a久久综合婷婷| 亚洲国产精品ⅴa在线观看| 午夜精品久久久久久久久久久久久 | 欧美理论片在线观看| 久久亚洲一区二区三区四区| 国产精品日韩欧美大师| 亚洲裸体视频| 在线视频你懂得一区二区三区| 久久综合中文| 欧美成人综合| 亚洲韩国青草视频| 久久蜜桃香蕉精品一区二区三区| 久久精品夜色噜噜亚洲a∨| 国产精品视频福利| 亚洲一区三区视频在线观看| 欧美一区二区播放| 国产一区二区三区奇米久涩| 久久精品人人| 欧美风情在线观看| 亚洲精品一区二区三区四区高清| 亚洲欧洲在线看| 亚洲免费观看在线观看| 国产精品日韩在线一区| 999亚洲国产精| 亚洲一区二区影院| 欧美美女bb生活片| 日韩香蕉视频| 亚洲在线观看视频| 国产精品一区=区| 欧美一区二区三区在线免费观看| 久久久久国产精品一区三寸| 国产在线欧美日韩| 久久综合色天天久久综合图片| 欧美激情bt| 在线午夜精品自拍| 国产女主播一区| 久久国产色av| 欧美黄在线观看| 亚洲欧美国产日韩中文字幕| 国产精品美女主播| 久久国产精品久久国产精品| 亚洲成人在线视频网站| 一本一本久久a久久精品牛牛影视| 欧美香蕉大胸在线视频观看| 亚洲欧美国产不卡| 欧美xx视频| 亚洲在线视频观看| 国产一区二区三区免费在线观看| 老色批av在线精品| 99re热这里只有精品视频| 欧美在线免费观看视频| 亚洲电影在线看| 欧美午夜视频| 浪潮色综合久久天堂| 一本久道久久综合婷婷鲸鱼| 久久精品国产亚洲一区二区三区| 亚洲精品美女91| 国产亚洲成年网址在线观看| 欧美91福利在线观看| 亚洲无线一线二线三线区别av| 欧美成ee人免费视频| 午夜亚洲福利| 99精品福利视频| 在线观看欧美日本| 国产精品手机在线| 欧美大片一区二区| 欧美影片第一页| 亚洲视频一区二区| 亚洲第一中文字幕| 欧美在线一区二区| 一本色道**综合亚洲精品蜜桃冫| 狠狠久久五月精品中文字幕| 国产精品二区三区四区| 欧美1区2区| 久久久久久亚洲精品杨幂换脸| 亚洲欧美国产日韩天堂区| 亚洲欧洲久久| 欧美激情精品久久久久久黑人| 久久精品国产一区二区三| 亚洲男女自偷自拍| 一区二区三区不卡视频在线观看| 激情一区二区三区| 国产日韩欧美视频在线| 欧美日韩一二三区| 欧美精品一区二区三| 久久这里有精品视频| 久久国内精品视频| 久久精品一区二区国产| 欧美一区二区三区精品电影| 亚洲一区免费| 国产精品99久久久久久白浆小说| 亚洲国产精品成人久久综合一区| 久久九九久精品国产免费直播| 小黄鸭视频精品导航| 亚洲欧美一区二区视频| 欧美高潮视频| 久久青草久久| 久久精品一区二区三区四区| 亚洲影视在线| 亚洲免费在线观看| 午夜精品久久久久久久久久久久 | 欧美日韩国产三级| 欧美另类videos死尸| 欧美日韩在线精品| 国产精品jizz在线观看美国| 国产精品久久久久国产精品日日 | 亚洲视频在线观看视频| 在线一区二区视频| 亚洲午夜在线观看视频在线| 亚洲天堂视频在线观看| 亚洲综合色自拍一区| 欧美亚洲自偷自偷| 久久午夜电影网| 欧美二区乱c少妇| 日韩一区二区精品葵司在线| 亚洲在线视频| 久久九九精品|