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

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

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


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

讓我們先來(lái)看個(gè)例題:

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

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

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


2.解決模式匹配問(wèn)題的方案:

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

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

?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????????????

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


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

???
我們通過(guò)樸素模式匹配的例子來(lái)引出問(wèn)題. 在第一次比較過(guò)程中失敗的是P的第4個(gè)字符b,這表明P的前4個(gè)字符是成功的.模式P的第3個(gè)字符b在它的前3個(gè)字符(aaa)中并未出現(xiàn).因此,在下一次比較時(shí)候,至少要將P向后移4個(gè)字符; 再看P的第一個(gè)字符與最后一個(gè)字符是相同的因此將P右移4個(gè)字符后 再?gòu)牡谝粋€(gè)字符比較 可定也是不等的.? 綜上所訴:應(yīng)該將P右移5個(gè)字符 再?gòu)?span lang="EN-US">P
的第0個(gè)字符和T的第5個(gè)字符開(kāi)始比較!

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

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

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

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


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

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

?????????????
???????????? 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;}

}


///////////////////
串類(lèi)的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 冬天¤不回來(lái) 閱讀(11377) 評(píng)論(15)  編輯 收藏 引用

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

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


QQ:41696402

<2015年9月>
303112345
6789101112
13141516171819
20212223242526
27282930123
45678910

常用鏈接

留言簿(3)

隨筆檔案

文章檔案

Programming

最新隨筆

搜索

  •  

積分與排名

  • 積分 - 39932
  • 排名 - 541

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            中文欧美日韩| 欧美一级大片在线观看| 午夜一区在线| 亚洲一区在线观看视频| 一区二区三区高清| 亚洲午夜av在线| 亚洲一二三区在线| 午夜视频在线观看一区二区三区 | 亚洲人成网在线播放| 另类天堂av| 亚洲国产精品成人| 在线综合+亚洲+欧美中文字幕| 亚洲欧洲综合| 亚洲影院免费| 久久在精品线影院精品国产| 老色鬼精品视频在线观看播放| 久久免费一区| 亚洲激精日韩激精欧美精品| 免费日韩一区二区| 亚洲精品资源| 欧美一区国产在线| 欧美精品在线免费播放| 欧美视频日韩视频在线观看| 欧美另类视频| 国产日韩欧美一区在线| 精品av久久707| 亚洲午夜av在线| 美日韩精品免费| 在线视频精品一区| 久久综合国产精品| 国产精品永久免费观看| 尤物九九久久国产精品的特点 | 欧美午夜精品理论片a级按摩| 国产精品igao视频网网址不卡日韩| 国产精品久久久久一区二区三区| 国产午夜亚洲精品理论片色戒| 在线成人免费观看| 欧美亚洲一区二区在线| 欧美激情亚洲另类| 欧美与欧洲交xxxx免费观看| 久久久亚洲一区| 国产精品v欧美精品∨日韩| 韩日欧美一区| 欧美一区二区女人| 99re6热在线精品视频播放速度| 午夜亚洲性色福利视频| 欧美噜噜久久久xxx| 亚洲视频免费观看| 久久嫩草精品久久久精品一| 欧美成人免费一级人片100| 国产精品三级视频| 亚洲午夜精品一区二区| 欧美大秀在线观看| 久久精品在这里| 国产亚洲精品自拍| 欧美在线播放视频| 中文日韩电影网站| 欧美色大人视频| 中文av字幕一区| 日韩视频―中文字幕| 久久亚洲精品中文字幕冲田杏梨| 国产精品视频导航| 亚洲欧美日韩天堂| 亚洲午夜在线观看| 国产精品久久久久久影视| 亚洲精品日韩久久| 亚洲国产美女| 欧美激情一区| 一区二区欧美在线| 99这里只有精品| 亚洲在线1234| 欧美一二三视频| 欧美亚洲在线播放| 99成人在线| 欧美一区二区在线| 国产精品无码永久免费888| 亚洲永久精品大片| 国产精品jvid在线观看蜜臀| 国产精品免费一区二区三区在线观看| 亚洲精品1区| 美女网站久久| 久久欧美肥婆一二区| 激情成人在线视频| 美女在线一区二区| 欧美 亚欧 日韩视频在线| 黄色成人av| 欧美成人久久| 欧美日韩三级电影在线| 亚洲最新中文字幕| 在线性视频日韩欧美| 欧美精彩视频一区二区三区| 狠狠久久五月精品中文字幕| 午夜精品一区二区三区四区| 亚洲免费大片| 久久漫画官网| 噜噜噜久久亚洲精品国产品小说| 亚洲国产一区二区三区a毛片| 欧美福利视频| 欧美日韩亚洲一区三区| 亚洲欧美综合v| 久久国产一二区| 99re成人精品视频| 欧美亚洲自偷自偷| 亚洲精品一区二区三区樱花| 欧美激情免费观看| 国产精品免费网站| 欧美承认网站| 国产精品免费小视频| 另类激情亚洲| 欧美午夜三级| 老鸭窝毛片一区二区三区| 欧美福利一区二区三区| 午夜国产欧美理论在线播放| 午夜精品一区二区三区在线视| 黄色一区二区在线| 亚洲主播在线| 一本久道久久综合中文字幕| 99精品国产在热久久下载| 国产亚洲欧美日韩一区二区| 久久永久免费| 国产精品一区二区男女羞羞无遮挡| 欧美1区2区| 国内精品久久久| 在线亚洲伦理| 欧美国产免费| 久久在线免费| 国产精品视频精品| 亚洲精品日韩激情在线电影| 国产精品青草综合久久久久99| 女人色偷偷aa久久天堂| 国产精品色一区二区三区| 亚洲高清不卡av| 一色屋精品亚洲香蕉网站| 亚洲色无码播放| 亚洲无限av看| 国产精品久久久久久久久久三级| 农村妇女精品| 在线观看91精品国产入口| 亚洲欧美欧美一区二区三区| 亚洲精品午夜| 欧美国产日韩视频| 亚洲国产成人不卡| 亚洲精品一区二区三区婷婷月 | 欧美国产激情| 136国产福利精品导航网址| 亚洲欧美另类久久久精品2019| 亚洲视屏一区| 国产精品都在这里| 1024国产精品| 欧美成人综合| 日韩视频在线一区二区三区| 亚洲成人直播| 欧美国产综合一区二区| 亚洲丰满少妇videoshd| 亚洲国产欧美一区二区三区久久| 久久精彩免费视频| 牛牛精品成人免费视频| 亚洲第一在线综合在线| 久久久久久亚洲精品不卡4k岛国| 久久精品视频一| 在线精品一区二区| 欧美另类videos死尸| 99在线热播精品免费| 亚洲欧美激情四射在线日 | 亚洲另类一区二区| 欧美日韩久久久久久| 一个色综合导航| 久久精品视频导航| 亚洲久久视频| 国产日韩欧美三级| 欧美成人蜜桃| 亚洲欧美中文字幕| 欧美国产日产韩国视频| 99综合在线| 国产综合av| 欧美日韩国产欧| 久久久久国产免费免费| 亚洲福利在线视频| 久久精品国产清自在天天线| 国产亚洲欧美另类一区二区三区| 久久在线免费| 亚洲一区免费观看| 亚洲黄色免费电影| 亚洲午夜在线观看视频在线| 欧美日韩色一区| 香蕉久久精品日日躁夜夜躁| 久久久久国产精品厨房| 亚洲国产小视频在线观看| 国产精品国产三级国产普通话三级 | 一本久久综合亚洲鲁鲁五月天| 国产精品区二区三区日本| 久久久综合香蕉尹人综合网| 欧美国产丝袜视频| 久久精品观看| 亚洲伊人一本大道中文字幕| 国产一区999| 国产精品久久久爽爽爽麻豆色哟哟| 久久嫩草精品久久久精品| 一本一本久久| 亚洲欧洲视频在线|