




已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 【正版授权】 IEC 60268-7:2025 CMV EN Sound system equipment - Part 7: Headphones and earphones
- 2024年河北省隆化县人民医院公开招聘护理工作人员试题带答案详解
- 洪洞教编初中数学试卷
- 医院项目管理课件
- 医院课件教学课件
- 《网络综合布线》教案 项目3实训任务 实施工程预算和撰写采购招标文件
- 健康管理中心课件内容
- 中国无线鼠标行业发展监测及投资战略规划研究报告
- 2021-2026年中国风光互补控制器市场竞争格局及投资战略规划报告
- 2025-2030年中国制动鼓行业市场供需态势及发展前景研判报告
- 2023-2024学年深圳市盐田区数学四下期末学业水平测试试题含解析
- 虚拟股权激励方案(模板)
- 2024-2029年中国管道运输行业发展分析及发展前景与投资研究报告
- 泰文租房合同
- 建筑维修与保养方法
- 金华出租车从业资格证模拟考试题
- (完整)中医症候积分量表
- 劳务外包三方协议
- 水果礼盒创业计划书
- 水产养殖行业营销策略方案
- 厂房分布式光伏系统施工进度计划横道图
评论
0/150
提交评论