- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
                        查看更多
                        
                    
                      
第4章
串
;本章要点;4.1.1 串的逻辑结构;课堂练习;4.1.2 串的基本运算(1);4.1.2 串的基本运算(2);课堂练习:;本章要点;4.2.1  串的顺序存储及基本运算的实现;存储表示;基于串的顺序存储结构的运算实现(1);基于串的顺序存储结构的运算实现(2);基于串的顺序存储结构的运算实现(3);课堂练习;算法代码;本章要点;1,什么是模式匹配?
	        假设有两个字符串ob和pat,若要在ob串中查找与pat串相等的子串,则称ob为主串,pat为模式串,并称这个运算为模式匹配.
2,模式匹配函数
             int find(string pat)//在串对象中,查找一个与串pat相同的子串,找到,返回其位置,否则返回-1。
            int  StrIndex_BF (int k, String p);	//简单模式匹配
            int StrIndex_KMP(int k, String p) ;	//KMP算法;	算法思想:
     设主串s=“ababcabcacbab”,模式t=“abcac”,匹配过程如下???所示:;设主串s=“ababcabcacbab”,模式t=“abcac”;Brute-Force算法思想:;find( String obj,string pat)
//从主串的第0个位置的字符开始比较
{
	int i=0,j=0;
	if(obj.curlen ==0 || pat.curlen == 0) //主串或pat为空
		return -1;
	while(i = obj.curlen  j = pat.curlen) //逐趟比较
	{
		if (obj.str[i] == pat.str[j])
		{
			i++;
			j++;
		}
		else
		{
			i=i-j+1;
			j=0;
		}
	}
	if(j == pat.cursize)
		return i-pat.cursize;
	return -1;
};模式匹配算法要点:;;模式匹配算法要点:;1,KMP算法的由来
        由D.E.Knuth,J.H.morris,V.R.pratt三个共同设计,是对Brute-Force算法的改进。
2, KMP算法
           设主串s=“aabcbabcaabcaababc”,子串t=“abcaababc”,下图是一个利用next函数进行匹配的过程示意图。    ;;在假设已有next函数情况下,KMP算法如下:
int findKMP(int k, String p,int f[]) 
{ 
     int i=0,j=0,pos;
     while(iob.size-1  jpat.size-1)
     {
             if (j== -1 ‖ob.str[i] == pat.str[j])
             {
                 i++;
                 j++;
              }
            else
                  j=f[j];
      }
     return(  j= pat.size-1 ?  i-j+1 : -1)
}
                您可能关注的文档
最近下载
- 大班社会《危险游戏我不玩》.pptx VIP
- 2025年山西运城事业单位考试笔试试题(含答案).pdf
- 城市轨道交通运营设备维修与更新技术规范第5部分:通信.pdf VIP
- 医院感染暴发事件应急处理.pptx VIP
- 《食品营养学》 课件 第四章 各类食物的营养特点.pdf
- 基于BIM的建设工程文件归档管理系统.pdf VIP
- 护理学(专升本)模考试题(含参考答案).docx VIP
- 员工离职申请表(模版)(标准版).doc VIP
- 实验五___DPS统计分析操作.pptx VIP
- 《Unit 3 Lesson 3 Letters all around》(说课稿)-2024-2025学年冀教版(三起)(2024)英语三年级上册.docx VIP
 原创力文档
原创力文档 
                        

文档评论(0)