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

首頁 > 編程 > C > 正文

C語言kmp算法簡單示例和實現原理探究

2020-01-26 15:17:48
字體:
來源:轉載
供稿:網友

以前看過kmp算法,當時接觸后總感覺好深奧啊,抱著數據結構的數啃了一中午,最終才大致看懂,后來提起kmp也只剩下“奧,它是做模式匹配的”這點干貨。最近有空,翻出來算法導論看看,原來就是這么簡單(下不說程序實現,思想很簡單)。

模式匹配的經典應用:從一個字符串中找到模式字串的位置。如“abcdef”中“cde”出現在原串第三個位置。從基礎看起

樸素的模式匹配算法

A:abcdefg  B:cde

首先B從A的第一位開始比較,B++==A++,如果全部成立,返回即可;如果不成立,跳出,從A的第二位開始比較,以此類推。

復制代碼 代碼如下:

/*
 *侯凱,2014-9-16
 *功能:模式匹配
 */
#include<iostream>
#include <string>
using namespace std;

int index(char *a,char *b)
{
    int tarindex = 0;
    while(a[tarindex]!='/0')
    {
        int tarlen = tarindex;
        int patlen;
        for(patlen=0;b[patlen]!='/0';patlen++)
        {
            if(a[tarlen++]!=b[patlen])
            {
                break;
            }
        }
        if(b[patlen]=='/0')
        {
            return tarindex;
        }
        tarindex++;
    }
    return -1;
}
int main()
{
    char *a = "abcdef";
    char *b = "cdf";
    cout<<index(a,b)<<endl;
      system("Pause");
}

思路樸實無華,十分有效,但是時間復雜度是O(mn),m、n分別是字符串和模式串的長度。模式匹配是一個常見的應用問題,用的廣了,就有人想法去優化了。Rabin-Karp算法、有限自動機等等,前仆后繼,最終出現了KMP(Knuth-Morris-Pratt)算法。

kmp算法

優化的地方:如果我們知道模式中a和后面的是不相等的,那么第一次比較后,發現后面的的4個字符均對應相等,可見a下次匹配的位置可以直接定位到f了。說明主串對應位置i的回溯是不必要的。這是kmp最基本最關鍵的思想和目標。

再比如:

由于abc 與后面的abc相等,可以直接得到紅色的部分。而且根據前一次比較的結果,abc就不需要比較了,現在只需從f-a處開始比較即可。說明主串對應位置i的回溯是不必要的。要變化的是模式串中j的位置(j不一定是從1開始的,比如第二個例子)

j的變化取決于模式串的前后綴的相似度,例2中abc和abc(靠近x的),前綴為abc,j=4開始執行。

j是前一次執行的模式子串(前幾個,上例為6)中前綴的個數+1;它與模式字串中從前向后的前綴和從后向前的后綴的相同子串是有關系的,因為下次這部分相同的前綴就會移動到這部分后綴的位置,因為如果移動到后綴的前面位置,看圖:

所以如果這次是j,下次的位置應該就是j前面的子串的最大前綴的長度+1,用這個新的位置再和原字符串的i位置進行比較就很幸福了。

這次是j,下次到底是多少呢,這就涉及到怎么計算的問題了?其實只看模式串我們就可以構建出這個j->x的關系,關系稱為前綴函數,結果存儲在數組中,稱為前綴數組。

偽代碼:

復制代碼 代碼如下:

compiter-prefix-function(P)
    m<-length[p]
    pi[1]<-0
    k<-0
    for q<-2 to m
        do while k>0 and P[k+1]!=P[q]
                    do k<-pi[k] //前綴的前綴...
           if P[k+1]==P[q]
                    then k<-k+1
           pi[q]<-k
    return pi

使用前綴數組可很快地實現模式匹配,程序匹配字符串中模式出現的所有位置。

復制代碼 代碼如下:

kmp-matcher(T, P)
    n<-length[T]
    m<-length[P]
    pi<-compiter-prefix-function(P)
    q<-0
    for i<-1 to n
        do while q>0 and P[q+1]!=T[i]
            do q<-pi[q] //前綴的前綴...
        if P[q+1]==T[i]
            then q<-q+1
        if q==m
            then print “Pattern occurs with shift”i-m
                    q<-pi[q]

這兩段代碼思想完全相同,如果和前綴不同就比較前綴的前綴…,比較巧妙。如果kmp有難理解的地方,估計就是這段偽碼的了。

KMP算法的時間復雜度為O(n+m)。

這里需要強調一下,KMP算法的僅當模式與主串之間存在很多部分匹配情況下才能體現它的優勢,部分匹配時KMP的i不需要回溯,否則和樸素模式匹配沒有什么差別。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久av电影| 国产+成+人+亚洲欧洲| 综合欧美国产视频二区| 欧美在线免费观看| 亚洲国产高潮在线观看| 在线亚洲午夜片av大片| 亚洲伦理中文字幕| 狠狠躁夜夜躁久久躁别揉| 中文字幕亚洲欧美在线| 亚洲v日韩v综合v精品v| 国产在线观看91精品一区| 欧美日韩国产成人| 精品美女国产在线| 国产欧美一区二区三区久久人妖| 色老头一区二区三区| 日韩欧美在线免费观看| 在线视频中文亚洲| 亚洲欧洲视频在线| 国产偷国产偷亚洲清高网站| 色偷偷噜噜噜亚洲男人| 亚洲国产精品久久久久秋霞蜜臀| 成人免费福利视频| 成人美女av在线直播| 97久久久久久| 欧美日韩免费看| 欧美激情视频在线| 91av在线精品| 亚洲视频在线观看免费| 亚洲成色777777女色窝| 亚洲欧洲在线看| 一本色道久久88综合亚洲精品ⅰ| 成人黄色中文字幕| 亚洲欧美日韩久久久久久| 日韩天堂在线视频| 欧美美女操人视频| 国产精品私拍pans大尺度在线| 热re99久久精品国产66热| 久久视频国产精品免费视频在线| 国产日韩欧美视频在线| 欧美在线不卡区| 国外色69视频在线观看| 亚洲国产成人精品女人久久久| 久久精品国产v日韩v亚洲| 国产精品福利在线观看| 亚洲国产精品va在线看黑人动漫| 国产一区二区日韩精品欧美精品| 久久全球大尺度高清视频| 欧美成人自拍视频| 热re91久久精品国99热蜜臀| 中文字幕9999| 国产一区二区三区在线免费观看| 中文字幕欧美日韩| 国产成人福利网站| 亚洲理论电影网| 久久天天躁狠狠躁夜夜爽蜜月| 精品magnet| 色偷偷av一区二区三区| 性色av一区二区三区红粉影视| 欧美日韩国产二区| 亚洲自拍偷拍第一页| 91av成人在线| 国产精品成人免费视频| 亚洲在线免费看| 人妖精品videosex性欧美| 九九久久综合网站| 亚洲最大激情中文字幕| 欧美日韩成人网| 日韩久久午夜影院| 亚洲美女又黄又爽在线观看| 色www亚洲国产张柏芝| 日韩精品极品毛片系列视频| 国产成人一区三区| 97视频网站入口| 美日韩精品免费视频| 91中文字幕在线观看| 亚洲男女自偷自拍图片另类| 中文在线不卡视频| 欧美电影第一页| 精品精品国产国产自在线| 亚洲女人被黑人巨大进入| 久久久久国产一区二区三区| 久久成人免费视频| 亚洲国产精品推荐| 国产成人97精品免费看片| 亚洲精品美女在线观看播放| 欧美成人在线免费| 欧美日韩免费在线观看| 中文字幕久久久av一区| 92国产精品久久久久首页| 国产美女扒开尿口久久久| 668精品在线视频| 国产激情久久久久| 51色欧美片视频在线观看| 岛国av一区二区三区| 成人激情春色网| 欧美极品第一页| 97精品国产97久久久久久春色| 欧美性猛交xxxx富婆弯腰| 久久69精品久久久久久国产越南| 7m第一福利500精品视频| 亚洲天堂av综合网| 上原亚衣av一区二区三区| 亚洲第一网站男人都懂| 91在线直播亚洲| 国产亚洲欧洲高清一区| 欧美日韩精品国产| 国产精品99导航| 国产丝袜一区二区三区免费视频| 久久久久久久国产| 中文字幕亚洲欧美一区二区三区| 国产视频久久久久| 国产主播欧美精品| 精品国产一区二区三区在线观看| 欧美电影免费看| 国产亚洲欧洲高清一区| 日韩成人免费视频| 亚洲欧美综合精品久久成人| 欧美日韩综合视频网址| 亚洲午夜久久久久久久| 欧美韩国理论所午夜片917电影| 亚洲天堂日韩电影| 日韩免费精品视频| 成人国内精品久久久久一区| 亚洲毛片在线免费观看| 亚洲伊人第一页| 国产精品一区二区性色av| 国产美女精品视频免费观看| 国产精品久久久久久久久久东京| 中文字幕亚洲欧美日韩2019| 欧美尤物巨大精品爽| 久久中文字幕国产| 久久乐国产精品| 97国产精品人人爽人人做| 国产午夜精品一区理论片飘花| 欧美日韩精品在线| 日韩在线高清视频| 亚洲人成电影网| 欧美限制级电影在线观看| 亚洲日本中文字幕| 欧美另类在线播放| 欧美高跟鞋交xxxxhd| 麻豆国产精品va在线观看不卡| 亚洲日韩第一页| 精品视频在线观看日韩| 国产日韩精品在线| 欧美在线视频a| 国产91色在线|免| 欧美激情在线狂野欧美精品| 亚洲男人天堂视频| 欧美成年人视频| 日本亚洲欧洲色α| 久久精品国产精品亚洲| 久久久久久国产精品三级玉女聊斋| 色综合久久悠悠| 日韩精品中文字幕有码专区| 亚洲国产精品久久精品怡红院| 最近2019免费中文字幕视频三| 精品亚洲aⅴ在线观看| 成人欧美一区二区三区黑人孕妇| 欧美激情在线视频二区| 日韩av中文字幕在线| 中文字幕精品—区二区| 精品福利在线视频| 久久视频在线观看免费|