字符串匹配算法.doc_第1页
字符串匹配算法.doc_第2页
字符串匹配算法.doc_第3页
字符串匹配算法.doc_第4页
字符串匹配算法.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

3HorspoolBoyer-MooreKnuth-Morris-Pratt100000int BruteForceStringMatch(string str, string pattern)for( int i = 0; i = str.size()- pattern.size(); i+ )int j = 0;while( (j pattern.size() & (patternj = stri+j)j+;if( j = pattern.size()return i;return (-1);void ShiftTable(string pattern, int table, int l)for(int i = 0; i 127; i+)tablei = l;for(int j = 0; j l-1; j+)tablepatternj = l-1-j;void HorspoolMatch(string str, int table, string pSize)int main()string a = abcdefg;string mode = z;coutBruteForceStringMatch(a, mode)endl;return 0;#includeusing namespace std;const int HASH_SIZE=256;int tableHASH_SIZE;/255, void ShiftTable(char pattern)/*Table*/int m=strlen(pattern);for(int i=0;iHASH_SIZE;i+) tablei=m;for(int j=0;jm-1;j+) table patternj =m-1-j;int HorspoolMatching(char pattern,char text)/O(n)/*pre:patterntextpost:-1*/ShiftTable(pattern);int m=strlen(pattern);int n=strlen(text);int i=m-1;while(i = n-1) int k=0; / while(kt & t!=.) int times=5; while(times-) cinp; coutHorspoolMatching(p,t)endl; return 1; #include #include #include #include #ifndef ssize_t typedef off_t ssize_t; #endif using namespace std; void compute_last_occurrence(const string& needle , vector& last_occurrence) last_occurrence.resize(256,-1); for ( size_t i = 0 ; i needle.size() ; i+ ) last_occurrenceneedlei = i; void compute_prefix_function(const string& needle , vector& prefix_function) if ( needle.size() = 0 ) return; prefix_function.resize( needle.size() , 0 ); size_t d = 0 ; for ( size_t i = 1 ; i 0 & needled != needlei ) d = prefix_functiond-1; if ( needlei = needled ) d+; prefix_functioni=d; void compute_goodsuffix_heuristic( const string& needle ,vector& goodsuffix_heristic) string reverse_needle; copy( needle.rbegin() , needle.rend() , back_inserter( reverse_needle ) ); vector prefix_function,reverse_prefix_function; compute_prefix_function( needle , prefix_function ); compute_prefix_function( reverse_needle , reverse_prefix_function ); size_t m = needle.size(); goodsuffix_heristic.resize( m + 1 , m - prefix_function m - 1 ); for ( size_t l = 1 ; l l - t ) goodsuffix_heristicj = l - t ; void boyer_moore_matcher(const string& haystack,const string& needle) size_t n=haystack.size(); size_t m=needle.size(); if ( n = 0 | m = 0 | n m ) coutInvalid inputendl; return; vector last_occurrence; compute_last_occurrence(needle,last_occurrence); vector goodsuffix_heristic; compute_goodsuffix_heuristic( needle , goodsuffix_heristic ); size_t offset = 0 ; while ( offset = 0 & needlej = haystackoffset+j ) j-; if ( j 0 ) coutFind a match at offset offsetendl; offset += goodsuffix_heristic0; else offset += max( goodsuffix_heristicj+1 , j - last_occurrencehaystackoffset+j ); int main() string haystack,needle; while ( true ) coutInput the haystack:endl; getline(cin,haystack); coutInput the needle:endl; getline(cin,needle); coutMatch results:endl; boyer_moore_matcher(haystack,needle); #include #include #include #include using namespace std; int* GetNextVal(const char *s, int &len) len = strlen(s); int *next = new intlen; int i = 0; int j = -1; next0 = -1; while(ilen-1)/KMP if(j=-1 | si=sj) +i; +j; nexti = j; else j = nextj; return next; int KMP(const char *s, const char *t) int slen,tlen; int i,j; int *next = GetNextVal(t, tlen); slen = strlen(s); i = 0; j = 0; while(islen & jtlen) if(j=-1 | si=tj) +i; +j; el

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论