• <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>
            posts - 3,  comments - 28,  trackbacks - 0

            看了兩三天的KMP算法,一直看的迷迷糊糊的.現(xiàn)在把這些資料貼在這里...以備日后之需
            ?
            1.串的模式匹配的改進(jìn)算法(這個(gè)網(wǎng)站對(duì)我的理解幫助很大,特別是右邊的那塊說明部分,以前自己腦筋老是轉(zhuǎn)不過來) http://cist.dhu.edu.cn/kejian/%CA%FD%BE%DD%BD%E1%B9%B9%BE%AB%C6%B7%BF%CE%B3%CC/%D4%DA%CF%DF%D1%A7%CF%B0/text/chapter04/section3/c5.htm

            2.KMP 算法的注記 http://www.cublog.cn/u/20/showart_136705.html?

            3.KMP算法中推導(dǎo)next[],nextval[]--手記 http://jiasimon040510.t8log.ccut.cn/blog-htm-do-showone-tid-6983.html


            4.算法原理:

            在匹配過和中,當(dāng)主串中第i個(gè)字符與模式串中第j個(gè)字符“失配”時(shí)(s[i]!=t[j]),將模式串盡量向右移動(dòng),讓模式串中第k(k<j)個(gè)字符與si對(duì)齊繼續(xù)比較,

            要讓這個(gè)條件成立,那么在k之前的k個(gè)t字符[0 到 k-1]必須在i之前的k個(gè)s字符[i-k 到 i-1]相匹配即:

            ?? t[0, 1, 2...k-1] == s[i-k, i-k+1, i-k+2...i-1]???? ---(1)

            而由之前的部分匹配成功的結(jié)果可知:
            ??
            ?? t[0, 1, 2...j-1] == s[i-j, i-j+1, i-j+2...i-1]???? ---(2)
            ==>
            ?? t[j-k, j-k+1, j-k+2...j-1] == s[i-k, i-k+1, i-k+2...i-1]?? --(3)

            由(1)與(3)可得:

            ?? t[0, 1, 2...k-1] == t[j-k, j-k+1, j-k+2...j-1]???? ---(4)

            求出k值,就是next[j]的值了

            總之,相對(duì)我來說,算法不是很好懂.但是大家看到我這么笨的人到最后都能明白一二.大家就更沒有理由看不懂了,祝大家成功附上我的測(cè)試源碼:



            #include?
            < iostream >

            using ? namespace ?std;


            void ?GetNext( char ?t[],? int ?next[])
            {
            ????
            int ?j? = ? 0 ;
            ????
            int ?k? = ? - 1 ;
            ????next[j]?
            = ?k;
            ????
            int ?tlen? = ?strlen(t);

            ????
            while (j < tlen)
            ????
            {
            ????????
            if (k? == ? - 1 ? || ?t[j]? == ?t[k])
            ????????
            {
            ????????????j
            ++ ;
            ????????????k
            ++ ;
            ????????????
            if (t[j]? == ?t[k])
            ????????????
            {
            ????????????????next[j]?
            = ?next[k];
            ????????????}

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

            ????????
            else
            ????????
            {
            ????????????k?
            = ?next[k];
            ????????}

            ????}

            }



            int ?KMP( char ?s[],? char ?t[],? int ?pos,? int ?next[])
            {
            ????
            int ?slen? = ?strlen(s);
            ????
            int ?tlen? = ?strlen(t);
            ????
            int ?i? = ? 0 ;
            ????
            int ?j? = ? 0 ;

            ????
            while (i < slen? && ?j < tlen)
            ????
            {
            ????????
            if (j? == ? - 1 ? || ?s[i]? == ?t[j])
            ????????
            {
            ????????????i
            ++ ;
            ????????????j
            ++ ;
            ????????}

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

            ????}


            ????
            if (j? == ?tlen)
            ????
            {
            ????????
            return ?i - tlen;
            ????}

            ????
            else
            ????????
            return ? - 1 ;
            }


            int ?main?( int ?argc,? char ? ** argv)
            {
            ????
            ????
            char ?s[]? = ? " aaaabaabaaabaaabaaaaabaaabaaabaaabaaabaaabaaabaaabaaabaaabacb " ;
            ????
            ????
            char ?t[]? = ? " aabaaa " ;

            ????
            int ?next[ 20 ] = { 0 } ;
            ????GetNext(t,?next);????
            ????
            for ( int ?i = 0 ;?i < 20 ;?i ++ )
            ????????cout
            << " next[ " << i << " ]:?? " << next[i] << endl;
            ????
            ????cout
            << KMP(s,?t,? 0 ,?next) << endl;
            }
            posted on 2006-11-10 01:51 豬頭餅 閱讀(1517) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 算法/數(shù)據(jù)結(jié)構(gòu)
            <2007年5月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            •  

            積分與排名

            • 積分 - 7378
            • 排名 - 1349

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久本道综合久久伊人| 久久不射电影网| 久久综合亚洲鲁鲁五月天| 亚洲综合伊人久久大杳蕉| 国产亚洲欧美精品久久久| 国产成人精品久久| 亚洲欧美成人综合久久久| 亚洲国产精品人久久| 久久久久波多野结衣高潮| 国产午夜精品久久久久免费视 | AV无码久久久久不卡网站下载| 国产精品一久久香蕉产线看| 亚洲精品无码专区久久同性男| 国产午夜免费高清久久影院| 亚洲Av无码国产情品久久| 久久精品人成免费| 三级三级久久三级久久 | 青青久久精品国产免费看| 国产午夜福利精品久久2021| 人妻无码αv中文字幕久久琪琪布| 精品综合久久久久久88小说| 1000部精品久久久久久久久| 久久国产免费直播| 久久亚洲中文字幕精品一区| 久久综合精品国产一区二区三区 | 久久久久久国产a免费观看不卡| 婷婷久久香蕉五月综合加勒比| 久久久久久噜噜精品免费直播| 久久精品一区二区国产| 久久99热只有频精品8| 97精品国产97久久久久久免费 | 亚洲精品无码成人片久久| 少妇人妻综合久久中文字幕| 亚洲人AV永久一区二区三区久久 | 色综合久久88色综合天天| 99久久免费国产精品热| 精品久久久久久久| 97久久精品人人澡人人爽| 国产精品激情综合久久| 久久精品国产精品亚洲艾草网美妙| 亚洲狠狠综合久久|