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

            Problem Solving using C++

            Algorithm Study using C++

            字符串匹配算法(3)---String Matching Algorithm

            由于有限自動(dòng)機(jī)方法與KMP算法類似,并且有限自動(dòng)機(jī)方法在預(yù)處理上的時(shí)間復(fù)雜度比KMP方法高,所以在本文的討論中,暫時(shí)不討論有限自動(dòng)機(jī)方法,主要是考慮KMP算法。
            KMP算法是一個(gè)非常有名的字符串匹配算法,其由Knuth,Morris和Pratt一起提出來的,預(yù)處理時(shí)間為O(m),其中m為匹配字符串的長度,匹配時(shí)間為O(n),其中n為需要匹配的字符串的長度。
            核心算法如下:
            //預(yù)處理部分
            int pi[m];
            pi[0]=0;
            int k = 0;

            for(int i=1;i<m;i++)
            {
               while((k>0)&&(p[i]!=p[k])
                   k=pi[k];

               if(p[i]==p[k])
                   k++;

               pi[i]=k;
            }

            //匹配部分
            int k=0;
            for(int i=0;i<n;i++)
            {
                while((k>0)&&(p[k]!=t[i]))
                       k=pi[k];
             
                 if(p[k]==t[i])
                      k++;

                  if(k==m)
                   {
                        //輸出結(jié)果,從(i+1-m)開始已經(jīng)匹配
                        k=pi[m-1];//開始下一個(gè)匹配
                   }
            }

            具體的可運(yùn)行的實(shí)現(xiàn)代碼為:
             1 #include <iostream>
             2 #include <string>
             3 
             4 using namespace std;
             5 
             6 int main(int argc,char* argv[])
             7 {
             8     char *t=NULL,*p=NULL;
             9     int *pi=NULL;
            10     string text,pattern;
            11 
            12     while(1)
            13     {
            14         cin>>text>>pattern;
            15         int n = text.length();        
            16         int m = pattern.length();
            17 
            18         //t= new char[n+1];
            19         //p= new char[m+1];
            20         t= new char[n];
            21         p= new char[m];
            22         pi = new int[m];
            23 
            24         //strcpy(t,text.c_str());
            25         //strcpy(p,pattern.c_str());
            26         memcpy(t,text.data(),n);
            27         memcpy(p,pattern.data(),m);
            28 
            29         //calculate the PI array
            30         int q = 0;
            31         pi[0]=0;
            32 
            33         for(int i=1;i<m;i++)
            34         {
            35             while((q>0)&&(p[q]!=p[i]))
            36             {
            37                 q=pi[q];
            38             }
            39 
            40             if(p[q]==p[i])
            41                 q++;
            42 
            43             pi[i]=q;
            44         }
            45 
            46         //use the KMP matching algorithm
            47         q = 0;
            48         for(int i=0;i<n;i++)
            49         {
            50             while((q>0)&&(p[q]!=t[i]))
            51             {
            52                 q = pi[q];
            53             }
            54 
            55             if(p[q]==t[i])
            56                 q++;
            57 
            58             if(q==m)
            59             {
            60                 cout<<((i+1)-m)<<endl;
            61                 q = pi[m-1];
            62             }
            63         }
            64 
            65         delete[] t;
            66         delete[] p;
            67         delete[] pi;
            68     }
            69 
            70     system("pause");
            71     return 0;
            72 }
            73 


            posted on 2007-08-21 14:37 Kingoal Lee's Alogrithm Study using cplusplus 閱讀(1875) 評(píng)論(2)  編輯 收藏 引用

            Feedback

            # re: 字符串匹配算法(3)---String Matching Algorithm 2007-08-23 11:07 金慶

            有錯(cuò)誤!測(cè)試如下,竟輸出2!

            abbbababbbbb
            ababab
            2
              回復(fù)  更多評(píng)論   

            # re: 字符串匹配算法(3)---String Matching Algorithm 2007-08-23 12:42 Kingoal Lee's Alogrithm Study using cplusplus

            @金慶
            嗯,我剛剛測(cè)試了一下,發(fā)現(xiàn)上面的出錯(cuò)。
            非常感謝你給我指出來!

            需要修改的是第52行,將其改為:
            q = pi[q-1];
            抱歉!  回復(fù)  更多評(píng)論   



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


            My Links

            Blog Stats

            常用鏈接

            留言簿(1)

            隨筆檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            精品精品国产自在久久高清| 草草久久久无码国产专区| 久久这里有精品| 久久夜色精品国产亚洲| 久久婷婷五月综合国产尤物app| 国产产无码乱码精品久久鸭| 精品水蜜桃久久久久久久| 亚洲天堂久久久| 99久久免费只有精品国产| 亚洲中文字幕无码久久精品1| 青青青伊人色综合久久| 精品久久久久久久久免费影院| 国产麻豆精品久久一二三| 一级女性全黄久久生活片免费| jizzjizz国产精品久久| 欧美亚洲国产精品久久高清| 久久黄视频| 精品久久一区二区三区| 国内精品久久久久久久久电影网| 亚洲国产精品久久久久| 久久99精品久久久久久hb无码 | 国产精品久久久久久久app| 久久久久国产精品熟女影院| 无码国内精品久久人妻麻豆按摩| 激情伊人五月天久久综合| 狠狠色婷婷久久综合频道日韩 | 久久人妻少妇嫩草AV蜜桃| 国产精品免费久久| 久久国产精品99久久久久久老狼| 三上悠亚久久精品| 狠狠色噜噜色狠狠狠综合久久| 午夜精品久久久久久| 成人午夜精品久久久久久久小说 | 久久久久综合国产欧美一区二区| 2022年国产精品久久久久| 狠狠色丁香久久婷婷综合五月| 亚洲女久久久噜噜噜熟女| 人妻无码αv中文字幕久久 | 久久电影网一区| 久久婷婷久久一区二区三区| 成人久久精品一区二区三区|