版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1.3实验项目——串匹配问题
1.实验题目给定一个文本,在该文本中查找并定位任意给定字符串。
2.实验目的⑴深刻理解并掌握蛮力法的设计思想;⑵提高应用蛮力法设计算法的技能;⑶
理解这样一个观点:用蛮力法设计的算法,一般来说,经过适度的努力后,都可以对算法的第一个版本进行一定程度的改良,改进其时间性能。
3.实验要求⑴实现BF算法;⑵实现BF算法的改进算法:KMP算法和BM算法;⑶
对上述三个算法进行时间复杂性分析,并设计实验程序验证分析结果。
4.实验提示(1)BF算法intBF(charS[],charT[]){i=1;j=1;while(i<=S[0]&&j<=T[0]&&j<=T[0])){if(S[i]==T[j]){i++;j++;}else{i=i-j+2;j=1;}}if(j>T[0])return(i-j+1);elsereturn0;}(2)KMP算法typedefstruct{ charch[MaxSize]; intlen;}SString;voidGetNext(SStringt,intnext[])//由模式串t求next的值{ intj,k; j=0;k=-1;next[0]=-1; while(j<t.len-1) { if(k==-1||t.ch[j]==t.ch[k]) //k为-1或比较的字符相等时 { j++;k++; next[j]=k; } elsek=next[k]; }}intKMPIndex(SStrings,SStringt){ intnext[MaxSize],i=0,j=0,v; GetNext(t,next); while(i<s.len&&j<t.len) { if(j==-1||s.ch[i]==t.ch[j]) { i++;j++; //i、j各增1 } elsej=next[j]; //i不变,j后退 } if(j>=t.len)v=i-t.len; //返回模式匹配的首字符下标 elsev=-1; //返回不匹配标志 returnv;}(3)BM算法intBM(charS[],charT[],intn,intm){//主串的长度为n,模式串的长度为m,主串和模式的数组下标从1开始 i=m; while(i<=n) { j=m; while(j>0&&S[i]==T[j]) { i--;j--; } if(j==0)returni+1; elsei+=dist(S[i
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 道客企业安全培训课件
- 2025心脏手术药物治疗管理指南解读课件
- 返修工作站培训课件
- 中考语文文言文对比阅读(全国)15《记承天寺夜游》对比阅读16组80题(解析版)
- 位危险源辨识试题
- 车险承保实务培训课件
- 木材加工场干燥车间建设方案
- 金属非金属地下矿山支柱工班组试题
- 《滑轮》教案物理科课件
- 2026年生产车间班长年终工作总结范例(二篇)
- 运输管理组组长安全生产岗位责任制模版(2篇)
- 2025届山西省阳泉市阳泉中学高二生物第一学期期末质量检测试题含解析
- 毒理学中的替代测试方法
- DB3502-Z 5026-2017代建工作规程
- 广东省大湾区2023-2024学年高一上学期期末生物试题【含答案解析】
- 第四单元地理信息技术的应用课件 【高效课堂+精研精讲】高中地理鲁教版(2019)必修第一册
- 提高隧道初支平整度合格率
- 2023年版测量结果的计量溯源性要求
- GB 29415-2013耐火电缆槽盒
- 中国古代经济试题
- 软件定义汽车:产业生态创新白皮书
评论
0/150
提交评论