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

隨筆 - 25, 文章 - 0, 評論 - 6, 引用 - 0
數據加載中……

KMP 匹配算法

一:BF算法
     如果讓你寫字符串的模式匹配,你可能會很快的寫出樸素的bf算法,至少問題是解決了,我想大家很清楚的知道它的時間復雜度為O(MN),原因很簡單,主串和模式串失配的時候,我們總是將模式串的第一位與主串的下一個字符進行比較,所以復雜度高在主串每次失配的時候都要回溯,圖我就省略了。

 二:KMP算法
   剛才我們也說了,主串每次都要回溯,從而提高了時間復雜度,那么能不能在“主串”和“模式串”失配的情況下,主串不回溯呢?而是讓”模式串“向右滑動一定的距離,對上號后繼續進行下一輪的匹配,從而做到時間復雜度為O(M+N)呢?所以kmp算法就是用來處理這件事情的。


代碼:
#pragma once

#include <iostream>

//                --- 樸素匹配算法 --- 

int NaiveMatch(const char * txt, const char * pat)  
{
    int  nTxtLength = strlen(txt);
    int  nPatLength = strlen(pat);
    int  nTxt = 0;
    int  nPat = 0;
    int nCount = 0; // 計數

    while (nTxt <= nTxtLength - nPatLength && nPat < nPatLength)  
    {
        ++nCount;

        if (pat[nPat] == txt[nTxt+nPat])
        {
            ++nPat;
        }
        else
        {
            ++nTxt;
            nPat = 0;
        }
    }

    std::cout << "NaiveMatch, compare counts: " << nCount << std::endl;

    return  (nPat == nPatLength ? nTxt : -1);




//                --- KMP 匹配算法 ---

void GetNext(const char* pattern, int next[])
{
    next[0] = 0;

    int j = 0;
    for (int i = 1; i < strlen(pattern); i++)
    {
        while( j > 0 && pattern[j] != pattern[i] )
        {
            j = next[j-1];
        }

        if (pattern[j] == pattern[i])
            j++;

        next[i] = j;
    }
}

int KMPMatch(const char* src, const char* pattern, int next[])
{
    int nSrc = 0;
    int nPattern = 0;
    int nCount = 0; // 計數

    while(nSrc < strlen(src) && nPattern < strlen(pattern))
    {
        ++nCount;
        if (0 == nPattern || src[nSrc] == pattern[nPattern])
        {
            ++nPattern;
            ++nSrc;
        }
        else
        {
            nPattern = next[nPattern];
        }
    }

    std::cout << "KMP, compare counts: " << nCount << std::endl;

    return (nPattern == strlen(pattern) ? nSrc - nPattern : -1);
}



#define PRINT_RESLUT(v) { if(-1 == (v)) std::cout << "No Find!"; else std::cout << "Position = " << (v); std::cout << std::endl << std::endl; }

int main()
{
    const char* Src        = "abc1aabc1aabc1aaababc1aababc1aabc1aaabc1aabc1aababc1aaabaabcbc1aa";
    const char* Pattern = "abaabc";

    int nPos = -1; // 保存匹配到的位置

    /// 樸素匹配算法
    nPos = NaiveMatch(Src, Pattern);
    PRINT_RESLUT(nPos);

    /// KMP匹配算法
    int next[6] = {0};
    GetNext(Pattern, next);
    nPos = KMPMatch(Src, Pattern, next);
    PRINT_RESLUT(nPos);
   
   system("pause");
   return 0;     
}

運行結果:


疑惑:為什么KMP的效率會更低?

posted on 2013-03-20 19:06 chenjt3533 閱讀(306) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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一区二区| 开元免费观看欧美电视剧网站| 久久黄金**| 欧美不卡一区| 欧美视频日韩| 国产欧美日韩亚洲精品| 狠狠色丁香婷婷综合影院 | 国产欧美日本一区二区三区| 国产欧美欧美| 亚洲国产成人精品女人久久久| 91久久在线视频| 亚洲一区二区三区精品在线| 欧美在线不卡视频| 欧美激情一区二区三区在线 | 久久国产欧美| 乱码第一页成人| 国产精品久久久久久影视| 国模精品一区二区三区| 日韩一区二区免费看| 久久xxxx| 99国产一区二区三精品乱码| 午夜亚洲性色福利视频| 欧美成年人网站| 国产欧美日韩免费| 日韩性生活视频| 久久久夜夜夜| 在线视频免费在线观看一区二区| 久久久在线视频| 国产精品美女xx| 91久久综合亚洲鲁鲁五月天| 欧美一级视频免费在线观看| 亚洲国内欧美| 久久精品国产亚洲5555| 国产精品扒开腿爽爽爽视频| 亚洲国产欧美精品| 久久欧美中文字幕| 亚洲欧美伊人| 欧美区高清在线| 在线国产亚洲欧美| 久久久av网站| 西瓜成人精品人成网站| 国产精品高清在线| 一本色道久久综合亚洲精品高清| 美女主播一区| 久久精品99国产精品酒店日本| 欧美日韩中文字幕在线| 可以免费看不卡的av网站| 国产裸体写真av一区二区| 一区二区三区四区国产精品| 欧美国产精品专区| 久久久久久久久伊人| 国产一区二区三区直播精品电影| 欧美一区二区国产| 亚洲自拍偷拍视频| 国产精品综合| 久久av在线| 久久激情五月丁香伊人| 国产专区综合网| 久久精品在这里| 久久精品一区四区| 激情欧美国产欧美| 欧美国产激情| 欧美r片在线| 亚洲肉体裸体xxxx137| 亚洲大胆美女视频| 欧美日韩四区| 欧美诱惑福利视频| 欧美中文在线视频| 亚洲二区在线视频| 亚洲激情偷拍| 欧美网站大全在线观看| 亚洲欧美日本国产专区一区| 亚洲欧美激情四射在线日| 国产日韩精品综合网站| 久久婷婷国产综合精品青草| 久久久免费精品| 亚洲免费观看高清在线观看 | 久久天天狠狠| 久久综合影视| 99国产精品久久久久久久久久| 亚洲精品自在久久| 国产精品羞羞答答xxdd| 久久深夜福利免费观看| 麻豆成人小视频| 亚洲免费在线精品一区| 久久精品99久久香蕉国产色戒| 亚洲黄色成人久久久| 日韩亚洲欧美精品| 国内伊人久久久久久网站视频 | 一区二区三区在线视频免费观看| 欧美激情1区2区| 国产精品v欧美精品v日韩精品 | 一本色道久久综合亚洲精品高清| 国产精品自拍一区| 91久久精品国产| 国产日韩欧美精品| 亚洲精品免费一二三区| 国产日韩视频| 99国内精品久久久久久久软件| 国产精品视屏| 欧美日产国产成人免费图片| 久久国产天堂福利天堂| 欧美成人一品| 久久人人爽爽爽人久久久| 欧美三日本三级少妇三2023| 麻豆九一精品爱看视频在线观看免费| 欧美精选一区| 牛夜精品久久久久久久99黑人| 国产精品高清网站| 亚洲国产综合91精品麻豆| 好吊日精品视频| 亚洲欧美国产毛片在线| 亚洲视频免费在线| 欧美国产日韩视频| 欧美va亚洲va香蕉在线| 国产一区二区三区日韩欧美| 中文无字幕一区二区三区| 日韩亚洲一区二区| 欧美sm重口味系列视频在线观看| 久久久综合网| 国产一区二区三区不卡在线观看 | 中文在线资源观看网站视频免费不卡| 久久久.com| 久久久久久网址| 国产一区二区三区奇米久涩| 亚洲欧美日本精品| 性欧美超级视频| 国产精品看片你懂得| 99国产一区| 亚洲伊人伊色伊影伊综合网| 欧美日韩精品二区第二页| 亚洲国产精品一区二区三区| 亚洲高清精品中出| 美女主播一区| 亚洲国产视频直播| 亚洲蜜桃精久久久久久久| 欧美激情第1页| 亚洲精品一区在线观看| 一个人看的www久久| 欧美日韩视频一区二区| 9色精品在线| 欧美亚洲视频在线观看| 国产一区二区三区黄视频| 久久精品五月婷婷| 欧美国产日韩一区二区| 99国产欧美久久久精品| 欧美特黄一级大片| 午夜精品亚洲| 欧美成人一区二免费视频软件| 亚洲精品久久在线| 国产精品多人| 久久精品亚洲一区二区| 欧美激情视频在线播放| 亚洲尤物在线视频观看| 国内外成人免费激情在线视频网站| 久久久之久亚州精品露出| 亚洲区免费影片| 亚洲一区二区三区四区五区黄| 国产欧美日韩亚洲精品| 美日韩精品免费| 亚洲午夜一区二区三区| 久热国产精品视频| 国产精品99久久久久久人| 国产性色一区二区| 欧美国产精品劲爆| 亚洲永久在线| 欧美一区三区二区在线观看| 亚洲一区久久久| 国内精品久久久久国产盗摄免费观看完整版 | 亚洲性感美女99在线| 久久成人精品视频| 亚洲经典在线看| 国产精品自拍三区| 蜜桃视频一区| 亚洲欧美在线免费| 亚洲日本中文字幕| 巨乳诱惑日韩免费av| 亚洲在线视频网站| 亚洲第一区在线| 国产人妖伪娘一区91| 欧美精品一区二区三区蜜桃| 久久福利电影| 亚洲视频欧洲视频| 亚洲国产精品激情在线观看| 久久国产精品久久久| 一区二区精品在线观看| 亚洲福利视频二区| 国产一区二区三区精品久久久 | 欧美日韩在线免费观看| 久久婷婷蜜乳一本欲蜜臀| 亚洲新中文字幕| 亚洲美女精品成人在线视频| 欧美风情在线观看| 久久影视精品| 久久久综合网站| 久久久久久久综合狠狠综合|