第5章串.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第5章串剖析

5. 插入子串 在字符串r中的指定位置i插入子串r1。 str *InsStr (Str *r, Str *r1,int i) { if ( i=r-len || r-len+r1-lenMAXLEN ) printf (不能插入!); else { for ( k=r-len-1;k=i;k--) r-vec[r1-len+k]=r-vec[k]; // 后移空出位置 for (k=0;kr1-len;k++) r-vec[i+k]=r1-vec[k]; // 插入子串r1 r-len=r-len+r1-len; r-vec[r-len]=\0; } return r; } 6.删除子串 在给定字符串r中删除从指定位置i开始连续j个字符。 void DelStr(Str *r,int i,int j) // i为指定删除的位置, j为连续删除的字符个数 { if (i+j-1r-len) printf (所要删除的子串超界!); else { for (k=i+j;kr-len;k++,i++) r-vec[i]=r-vec[k]; // 将后面的字符串前移覆盖 r-len=r-len-j; r-vec[r-len]=\0; } } 7. 模式匹配 模式匹配即子串定位运算。设s和t是给定的两个串,在主串s中找到等于子串t的过程称为模式匹配。其中被匹配的主串s称为目标串,匹配的子串t称为模式。 (1)基本思想: 首先将s1与t1进行比较,若不同,就将s2与t1进行比较,直到s的某一个字符si和t1相同,再将它们之后的字符进行比较,若也相同,则如此继续往下比较,当s的某一个字符si与t的字符tj不同时,则s返回到本趟开始字符的下一个字符,即si-j+2,t返回到t1,继续开始下一趟的比较,重复上述过程。若t中的字符全部比较完,则说明本趟匹配成功,本趟的起始位置是i–j+1,否则,匹配失败。 (2)模式匹配的例子 主串s="ABABCABCACBAB",模式t="ABCAC“。 动画演示2 动画演示1 (3)算法描述: 返回在字符串r中子串r1出现的位置。 int IndexStr(Str *r, Str *r1) { int i,j,k; for (i=0;r-vec[i];i++) for (j=i,k=0;r-vec[j]= =r1-vec[k];j++,k++) if (!r1-vec[k+1]) return i; return -1; } (4)时间复杂度分析 设串s长度为n,串t长度为m。匹配成功的情况下,考虑两种极端情况: 在最好情况下,每趟不成功的匹配都发生在第一对字符比较时: 例如:s="AAAAAAAAAABC" t="BC" 设匹配成功发生在si处,则字符比较次数在前面i-1趟匹配中共比较了i-1次,第i趟成功的匹配共比较了m次,所以总共比较了i-1+m次,所有匹配成功的可能共有n-m+1种,设从si开始与t串匹配成功的概率为pi,在等概率情况下pi=1/(n-m+1),因此最好情况下的平均比较次数是: 即最好情况下的时间复杂度是O(n+m)。 在最坏情况下,每趟不成功的匹配都发生在t的最后一个字符。 例如:s="AAAAAAAAAAAB" t="AAAB" 设匹配成功发生在si处,则在前面i-1趟匹配中共比较了(i-1)*m次,第i趟成功的匹配共比较了m次,所以总共比较了i*m次,因此最坏情况下平均比较的次数是: 因为nm,所以最坏情况下的时间复杂度是O (n*m)。 小 结 (1)串是有限个字符组成的序列,一个串的字符个数叫做串的长度,长度为零的字符串称为空串。 (2)串是一种特殊的线性表,规定每个数据元素仅由一个字符组成。 (3)串的顺序存储有非紧凑格式和紧凑格式两种,非紧凑格式存储操作简单,但内存浪费;紧凑格式可以节省内存,但操作却不方便。 (4)串的链式存储结构具有插入、删除方便的优点,但其存储密度很低;若采用紧凑的链式存储(一个结点放多个字符),虽

文档评论(0)

586334000 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档