• <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算法,一直看的迷迷糊糊的.現在把這些資料貼在這里...以備日后之需
            ?
            1.串的模式匹配的改進算法(這個網站對我的理解幫助很大,特別是右邊的那塊說明部分,以前自己腦筋老是轉不過來) 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算法中推導next[],nextval[]--手記 http://jiasimon040510.t8log.ccut.cn/blog-htm-do-showone-tid-6983.html


            4.算法原理:

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

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

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

            而由之前的部分匹配成功的結果可知:
            ??
            ?? 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]的值了

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



            #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 豬頭餅 閱讀(1520) 評論(0)  編輯 收藏 引用 所屬分類: 算法/數據結構
            <2006年11月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            •  

            積分與排名

            • 積分 - 7386
            • 排名 - 1349

            最新評論

            閱讀排行榜

            評論排行榜

            中文无码久久精品| 精品欧美一区二区三区久久久| 国产L精品国产亚洲区久久 | 久久无码AV中文出轨人妻| 亚洲国产精品久久久久婷婷软件 | 国产精品日韩深夜福利久久| 久久久精品久久久久特色影视| 久久久久亚洲av成人网人人软件| 久久婷婷成人综合色综合| 久久精品视频网| 久久成人国产精品免费软件| 国产精品视频久久| 中文字幕无码久久久| 久久国产成人精品麻豆| 欧美大战日韩91综合一区婷婷久久青草 | 亚洲国产精品无码久久98| 久久不射电影网| 色8久久人人97超碰香蕉987| 久久精品女人天堂AV麻| 久久精品国产亚洲AV无码娇色| 免费一级做a爰片久久毛片潮| 国产亚洲婷婷香蕉久久精品| 国产精品乱码久久久久久软件 | 久久成人影院精品777| 久久婷婷五月综合97色| 免费无码国产欧美久久18| 久久免费大片| 国产69精品久久久久9999| 久久精品国产亚洲av日韩| 国产成人久久精品一区二区三区 | 99久久精品国产一区二区三区| 亚洲国产精品高清久久久| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 久久综合精品国产二区无码| 97精品伊人久久大香线蕉| 久久天天躁狠狠躁夜夜不卡| 久久亚洲精品无码aⅴ大香| 久久最新免费视频| 久久婷婷五月综合色奶水99啪| 久久夜色精品国产亚洲av| 人人狠狠综合久久亚洲高清|