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

Problem Solving using C++

Algorithm Study using C++

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

前面已經(jīng)說到了naive的方法來匹配字符串,但是該方法的特點是復(fù)雜度高,未能充分利用計算得到的值作為下一步計算的結(jié)果,因此,復(fù)雜度相當(dāng)比較高。
Rabin-Karp提出了新的字符串匹配方法:
Rabin-Karp方法主要是分2部分:
(1)預(yù)處理(pre-processing)
對pattern字符串的m個進(jìn)行計算,得到其hash值。 復(fù)雜度為O(m)
(2)匹配(matching)
for(int i=0;i<n-m;i++)
{
    計算t[i..i+m]的hash值。
    再同pattern字符串的hash值進(jìn)行對比,如果相同,則使用naive辦法,繼續(xù)一個字符一個字符地比較。
    使用Horner法則計算下一個m字符的hash值。(即h(s+1)=f(h(s))).
}
整個算法的復(fù)雜度:
在最差的情況下,復(fù)雜度為O(m)+O(m*(n-m+1))
期望的情況為O(n-m+1+cm)=O(n+m).

實驗代碼如下:(暫時只是考慮支持12345678901234567890 匹配 234等的情況)
 1 #include <iostream>
 2 #include <string>
 3 
 4 using namespace std;
 5 
 6 #define Q    997 //Should be a prime
 7 #define D    10    //|sizeof character set|
 8 
 9 inline int geth(int m)//h=d^(m-1)%q
10 {
11     int len=1;
12     for(int i=0;i<(m-1);i++)
13     {
14         len*=D;
15     }
16     return len%Q;
17 }
18 
19 int main(int argc,char* argv[])
20 {
21     char *t=NULL,*p=NULL;
22     string text,pattern;
23     int h,p0=0,t0=0;
24 
25     while(1)
26     {
27         int index = 0;
28 
29         cin>>text>>pattern;
30         int n = text.length();        
31         int m = pattern.length();
32 
33         //t= new char[n+1];
34         //p= new char[m+1];
35         t= new char[n];
36         p= new char[m];
37 
38         h = geth(m);
39         p0=t0=0;
40 
41         //strcpy(t,text.c_str());
42         //strcpy(p,pattern.c_str());
43         memcpy(t,text.data(),n);
44         memcpy(p,pattern.data(),m);
45 
46         for(int i=0;i<m;i++)//get the initial value from pattern and text
47         {
48             p0 =(D*p0+(p[i]-'0'))%Q;
49             t0 = (D*t0+(t[i]-'0'))%Q;
50         }
51 
52         for(int i=0;i<(n-m);i++)
53         {
54             if(p0==t0)//should call the naive algorithm to check whether the two string is the same
55             {
56                 bool match = true;
57                 for(int j=0;j<m;j++)
58                 {
59                     if(p[j]!=t[i+j])
60                         match = false;
61                 }
62 
63                 if(match)
64                     cout<<i<<endl;
65             }
66 
67             t0 = ((D*(t0-(t[i]-'0')*h)+t[i+m])-'0')%Q;
68         }
69 
70         delete[] t;
71         delete[] p;
72     }
73 
74     system("pause");
75     return 0;
76 }
77 


posted on 2007-08-20 21:11 Kingoal Lee's Alogrithm Study using cplusplus 閱讀(472) 評論(0)  編輯 收藏 引用


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


My Links

Blog Stats

常用鏈接

留言簿(1)

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            老司机67194精品线观看| 欧美在线观看www| 亚洲日本中文| 永久91嫩草亚洲精品人人| 国产欧美视频在线观看| 国产欧美日本| 国产一区视频在线观看免费| 激情av一区| 亚洲美女淫视频| 亚洲一级特黄| 久久人人爽人人爽| 亚洲第一福利在线观看| 欧美国产综合视频| 日韩亚洲精品视频| 香蕉免费一区二区三区在线观看| 久久久久久久综合狠狠综合| 欧美激情一区二区三区全黄| 国产精品人人做人人爽人人添| 好看的日韩视频| 日韩网站在线观看| 久久精品一区四区| 亚洲巨乳在线| 欧美专区日韩专区| 欧美激情视频在线免费观看 欧美视频免费一| 欧美日韩一区二区三区免费| 黄色资源网久久资源365| 亚洲专区免费| 亚洲国产成人不卡| 久久av在线| 国产精品国内视频| 亚洲理论在线| 久久久久久久一区二区| 99成人精品| 女同性一区二区三区人了人一 | 亚洲片在线观看| 欧美中文字幕在线观看| 亚洲人成亚洲人成在线观看图片 | 亚洲一区在线观看视频 | 国内揄拍国内精品久久| 亚洲一区二区三区激情| 亚洲国产婷婷综合在线精品| 欧美一区在线看| 国产精品欧美激情| 亚洲久久成人| 欧美福利一区二区三区| 久久久久久久一区二区三区| 国产在线视频欧美| 亚洲影院免费观看| 99精品国产热久久91蜜凸| 欧美成年人网| 亚洲欧洲综合| 最新成人在线| 久久精品国产亚洲一区二区三区| 亚洲精品乱码久久久久久按摩观| 小处雏高清一区二区三区| 日韩香蕉视频| 欧美小视频在线观看| 宅男66日本亚洲欧美视频| 亚洲精品国产视频| 欧美日韩视频专区在线播放| 亚洲三级视频| 亚洲乱码国产乱码精品精可以看 | 亚洲伦理精品| 欧美激情精品久久久久久黑人| 久久久久在线观看| 亚洲成人直播| 欧美激情精品久久久久久黑人| 免费观看不卡av| 亚洲国产岛国毛片在线| 欧美激情亚洲国产| 欧美日韩三级视频| 性色av香蕉一区二区| 欧美影院成人| 亚洲电影在线看| 亚洲精品久久久久久一区二区| 欧美日本国产| 亚洲欧美一区二区视频| 欧美一级理论片| 亚洲国产成人av| 亚洲精品中文字| 国产欧美一级| 浪潮色综合久久天堂| 牛人盗摄一区二区三区视频| 一本色道久久综合亚洲精品不卡| 中国成人黄色视屏| 国自产拍偷拍福利精品免费一| 欧美www在线| 欧美日韩国产不卡| 欧美一区二区三区免费在线看| 久久九九全国免费精品观看| 99国产精品视频免费观看| 亚洲一区二区视频| 亚洲高清视频在线观看| 99在线精品观看| 揄拍成人国产精品视频| 日韩午夜精品| 伊人久久噜噜噜躁狠狠躁| 亚洲美女中文字幕| 国内在线观看一区二区三区| 亚洲毛片在线| 亚洲久久一区| 一区二区三区在线看| 日韩亚洲精品在线| 韩国一区二区三区美女美女秀| 亚洲区第一页| 亚洲国产高清在线观看视频| 亚洲免费影院| 夜夜嗨av一区二区三区四季av | 久久久福利视频| 在线视频精品| 久久亚洲影音av资源网| 中文久久乱码一区二区| 欧美一级理论性理论a| 亚洲裸体视频| 久久九九免费视频| 欧美在线免费播放| 欧美视频四区| 亚洲理论在线| 91久久在线| 久久久久久电影| 久久久久久久久久久一区| 国产精品99一区二区| 亚洲国产合集| 在线观看日韩欧美| 欧美在线观看一区| 欧美在线视频播放| 国产精品久久国产三级国电话系列 | 国产精品久久久久久福利一牛影视| 欧美bbbxxxxx| 国产一区二区三区免费在线观看| 在线亚洲电影| 亚洲尤物在线视频观看| 欧美视频一区二区| 一本色道久久综合精品竹菊 | 亚洲一区二区成人| 亚洲——在线| 国产精品露脸自拍| 亚洲欧美久久久| 久久成人av少妇免费| 国产女人水真多18毛片18精品视频| 一区二区三区偷拍| 香蕉成人啪国产精品视频综合网| 欧美视频在线免费看| 一区二区三区免费观看| 欧美一区=区| 国产一区三区三区| 蜜臀a∨国产成人精品 | 久久久青草婷婷精品综合日韩 | 国产欧美一区二区精品性色 | 欧美日韩在线视频观看| 在线午夜精品| 久久精品女人| 亚洲第一黄网| 欧美日本一区二区三区| 亚洲少妇自拍| 久久精品视频在线播放| 亚洲国产一区在线观看| 欧美激情久久久久| 一区二区三区精品| 久久综合九色99| 99re这里只有精品6| 国产精品一卡二卡| 久久最新视频| 亚洲少妇中出一区| 久久精品综合网| 亚洲精选视频在线| 亚洲国产你懂的| 国产一区二区精品久久99| 性久久久久久久| 欧美插天视频在线播放| 一区二区三区|亚洲午夜| 国产精品一区在线观看| 美女精品网站| 亚洲欧美精品| 91久久综合| 久久精视频免费在线久久完整在线看| 亚洲国产综合在线| 国产女人精品视频| 欧美日韩国产在线看| 久久精品99国产精品酒店日本| 亚洲三级影片| 久久欧美肥婆一二区| 亚洲午夜视频| 亚洲娇小video精品| 国产精品亚洲成人| 欧美激情a∨在线视频播放| 欧美在线播放| 亚洲一区二区伦理| 亚洲人成网站777色婷婷| 看片网站欧美日韩| 欧美在线视频免费观看| 宅男精品视频| 亚洲精品一区中文| 在线观看视频亚洲| 国精品一区二区三区| 国产精品一区二区你懂得 | 亚洲激情综合| 麻豆成人精品| 久久精品系列| 久久成人久久爱|