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

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

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


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

讓我們先來看個例題:

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

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

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


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

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

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


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

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

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

?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數(shù)組(關(guān)于修正我會在下次提到).
1:我們要算next[2]的值,有關(guān)的為P本身的前2個字符0,1.?? 在字符串01,尋找出?? "左右相同的最大字符串,此字符串所含字符的個數(shù)就為next[i]的值"0不等于1,相同字符串不存在,所以next[i] = 0;

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

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


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

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

?????????????
???????????? 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算法初學(xué)
2006-10-10 22:03 | 冬天¤不回來
今天真是郁悶,一下課就回來開門造車,寫KMP,花了3個小時寫了個很好的,結(jié)果一發(fā)表出去 卻變成一堆亂78糟的東西!!可能是因為顏色 下標(biāo) 大小寫等搞混淆了! 然后又花了40分鐘,刪的刪,改的改,最后出來這個讓我無語的版本.痛苦ED.
雖然刪了些,但精華還在,希望對大家有幫助.  回復(fù)  更多評論
  
# re: KMP算法初學(xué)
2006-12-29 22:06 | lily1115
沒有啊!很有特色!  回復(fù)  更多評論
  
# re: KMP算法初學(xué)
2007-01-04 20:30 | pengkuny
博主,能不能換個模板?
看著實在難受  回復(fù)  更多評論
  
# re: KMP算法初學(xué)
2007-04-14 16:03 | hotjuly
@冬天&#164;不回來
今天真是郁悶,一下課就回來開門造車,寫KMP,花了3個小時寫了個很好的,結(jié)果一發(fā)表出去 卻變成一堆亂78糟的東西!!可能是因為顏色 下標(biāo) 大小寫等搞混淆了! 然后又花了40分鐘,刪的刪,改的改,最后出來這個讓我無語的版本.痛苦ED.
====================================================================
誒,這個排版。。。
夠郁悶的,精神可嘉。
樓主可以在word中全部搞定,然后轉(zhuǎn)換成html的,然后從html全部復(fù)制到blog上,這樣排版應(yīng)該沒問題了。比較重要的文章可以轉(zhuǎn)換成pdf,提供下載,可以讓讀者線下瀏覽。www.51files.com 不錯的
btw:你們一幫人都在搞算法,什么專業(yè)的?  回復(fù)  更多評論
  
# re: KMP算法初學(xué)
2008-10-10 20:23 | yjw
寫得太好了   回復(fù)  更多評論
  
# re: KMP算法初學(xué)
2008-12-05 11:57 | hf
寫的確實不錯啊!!  回復(fù)  更多評論
  
# re: KMP算法初學(xué)[未登錄]
2009-09-30 08:37 | 123
有錯誤  回復(fù)  更多評論
  
# re: KMP算法初學(xué)
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.   回復(fù)  更多評論
  
# re: KMP算法初學(xué)
2011-11-03 16:57 | nono
@冬天&#164;不回來
思想還是錯了..  回復(fù)  更多評論
  
# re: KMP算法初學(xué)
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  回復(fù)  更多評論
  
# re: KMP算法初學(xué)
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....  回復(fù)  更多評論
  
# re: KMP算法初學(xué)
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  回復(fù)  更多評論
  
# re: KMP算法初學(xué)
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  回復(fù)  更多評論
  

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


QQ:41696402

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

常用鏈接

留言簿(3)

隨筆檔案

文章檔案

Programming

最新隨筆

搜索

  •  

積分與排名

  • 積分 - 40057
  • 排名 - 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>
            亚洲综合视频网| 鲁鲁狠狠狠7777一区二区| 国产欧美综合一区二区三区| 国产精品jizz在线观看美国| 欧美午夜一区二区三区免费大片 | 欧美精品性视频| 欧美女激情福利| 国产精品久久久久一区| 国内偷自视频区视频综合| 亚洲第一网站免费视频| 一本一本久久| 久久香蕉国产线看观看av| 亚洲电影免费| 一区二区三区视频在线看| 久久国产日韩欧美| 欧美精品久久久久久久免费观看 | 久久av一区二区| 午夜一区不卡| 欧美成人久久| 亚洲精品免费网站| 午夜伦欧美伦电影理论片| 欧美77777| 国产日韩亚洲欧美| 99av国产精品欲麻豆| 久久精品视频导航| 日韩一区二区精品葵司在线| 久久成人国产精品| 国产精品久久久久91| 亚洲国产精品精华液2区45| 亚洲欧美综合国产精品一区| 欧美激情一二三区| 欧美在线一区二区| 国产精品美女www爽爽爽| 91久久国产综合久久| 久久久精品国产一区二区三区| 99热精品在线观看| 欧美绝品在线观看成人午夜影视| 一区二区三区在线视频免费观看 | 亚洲一区图片| 亚洲国产美女| 久久久久久久一区| 国产视频久久久久| 欧美在线视频在线播放完整版免费观看| 亚洲国产欧美日韩| 久久免费精品视频| 黑人一区二区三区四区五区| 欧美一区激情| 香蕉久久夜色精品| 国产日韩欧美一二三区| 欧美亚洲在线视频| 亚洲欧美国产三级| 国产精品人人做人人爽| 9l国产精品久久久久麻豆| 亚洲电影视频在线| 欧美成人伊人久久综合网| 91久久精品美女高潮| 亚洲国产高清视频| 欧美黄色网络| 国产精品99久久99久久久二8 | 你懂的亚洲视频| 久久精品国产91精品亚洲| 国产亚洲欧美日韩一区二区| 久久久精品国产一区二区三区| 性欧美1819性猛交| 狠狠色丁香婷婷综合| 裸体素人女欧美日韩| 久久综合免费视频影院| 亚洲第一精品在线| 亚洲激情第一区| 久久aⅴ国产欧美74aaa| 欧美国产一区二区| 欧美精品电影| 亚洲欧美欧美一区二区三区| 午夜精品福利在线观看| 国内一区二区三区| 亚洲国产欧美精品| 欧美色偷偷大香| 欧美一区二区三区四区在线观看地址| 亚洲欧美视频| 亚洲欧洲免费视频| 亚洲午夜av| 在线观看国产成人av片| 亚洲国产免费看| 国产精品黄视频| 久久一区二区三区国产精品| 欧美激情一区在线观看| 亚洲欧美制服另类日韩| 久久午夜视频| 亚洲男人av电影| 另类尿喷潮videofree| 亚洲一区在线观看视频 | 久久九九免费| 在线视频精品| 久久亚洲私人国产精品va媚药 | 欧美xart系列高清| 欧美系列亚洲系列| 美女图片一区二区| 欧美日一区二区三区在线观看国产免| 久久精品人人做人人综合| 欧美日韩不卡视频| 久久综合狠狠| 国产精品免费视频xxxx| 亚洲国产乱码最新视频| 国内精品视频在线播放| 一本大道av伊人久久综合| 亚洲高清视频在线| 欧美亚洲免费电影| 亚洲性av在线| 欧美福利影院| 欧美大学生性色视频| 亚洲精品国产视频| 国产精品视频导航| 欧美激情亚洲精品| 国精品一区二区三区| 亚洲精品一级| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲女女做受ⅹxx高潮| 亚洲视频在线观看一区| 欧美大片在线影院| 欧美粗暴jizz性欧美20| 国产中文一区二区| 亚洲综合视频在线| 亚洲综合色噜噜狠狠| 欧美日韩第一区| 亚洲国产精品女人久久久| 在线观看91精品国产入口| 欧美一区二区三区免费大片| 亚洲男人的天堂在线观看| 在线视频你懂得一区| 久久精品视频免费| 午夜在线精品偷拍| 欧美性色综合| 一个色综合导航| 一本色道久久综合亚洲精品高清| 免费国产一区二区| 欧美成人一区二免费视频软件| 黄色成人av在线| 美女黄色成人网| 欧美国产欧美亚洲国产日韩mv天天看完整 | 看片网站欧美日韩| 国产欧美日韩精品a在线观看| 中文日韩在线| 欧美日韩理论| 欧美一区二区三区四区高清| 一区二区三区日韩欧美精品| 欧美大胆成人| 亚洲精品国产精品国自产观看浪潮| 亚洲国产精品123| 老色鬼精品视频在线观看播放| 老司机免费视频久久| 伊人久久大香线| 牛牛国产精品| 99视频一区二区三区| 亚洲欧美电影院| 国产一区二区三区四区老人| 久热精品视频| 99在线精品视频在线观看| 欧美一区二区三区四区视频| 韩国成人精品a∨在线观看| 毛片av中文字幕一区二区| 日韩一级大片在线| 久久精品一区蜜桃臀影院| 亚洲福利视频在线| 免费在线亚洲| 亚洲承认在线| 亚洲免费大片| 国产精品va在线| 欧美一区久久| 亚洲欧洲日本一区二区三区| 亚洲欧美中日韩| 亚洲高清一区二| 欧美日韩一区二区三区四区五区| 亚洲欧美卡通另类91av| 欧美国产日韩精品| 欧美亚洲网站| 在线中文字幕日韩| 在线免费观看欧美| 国产精品视频专区| 国产一区二区按摩在线观看| 最新亚洲电影| 久久精品国产一区二区三| 亚洲另类春色国产| 国产一区二区三区成人欧美日韩在线观看| 米奇777在线欧美播放| 亚洲综合999| 亚洲精品欧洲精品| 久久婷婷麻豆| 性欧美长视频| 亚洲私人影院在线观看| 亚洲国产精品一区制服丝袜| 国产欧美1区2区3区| 欧美日韩一区在线观看| 欧美大片免费看| 久久久精品2019中文字幕神马| 亚洲永久精品大片| 99国产精品久久久久久久成人热| 亚洲国产cao| 欧美黑人在线观看| 免费日韩一区二区| 久久久久久国产精品mv|