[理学]第四章串和 数组.pptVIP

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

4.1 串 4.1.1 串的定义 串是字符串的简称。它是一种在数据元素的组成上具有一定约束条件的线性表,即要求组成线性表的所有数据元素都是字符,所以,人们经常又这样定义串:串是一个有穷字符序列。 串一般记作:s= “a1a2...an” (n?0) 其中,s是串的名称,用双引号(“”)括起来的字符序列是串的值;ai可以是字母、数字或其他字符;串中字符的数目n被称作串的长度。当n=0时,串中没有任何字符,其串的长度为0,通常被称为空串。 如: 例如,有下列四个串a,b,c,d: a= “Welcome to Beijing” b= “Welcome” c= “Bei” d= “welcome to” 子串的位置:子串在主串中第一次出现的第一个字符的位置。 两个串相等:两个串的长度相等,并且各个对应的字符也都相同。 例如,有下列四个串a,b,c,d: a= “program” b= “Program” c= “pro” d= “program ” 4.1.1 串的基本运算: (1)计算串长度StrLength(s) (2)串赋值StrAssign(s1,s2) (3)串连接 StrConcat(s1,s2) (4)求子串 SubStr(s,i,len) (5)串比较 StrCmp(s1,s2) (6)串的定位 StrIndex(s,t) (7)串插入 StrInsert(s,i,t) (8)串删除 StrDelete(s,i,len) (9)串替换 StrRep(s,t,r) 4.1.2 串的定长顺序存储结构及基本运算 1. 串的定长顺序存储结构 串的顺序存储结构是用一组连续的存储单元依次存储串中的字符序列。实现方式: 事先定义字符串的最大长度,字符串存储在一个定长的存储区中。类型定义如下所示: #define MAXSIZE 256 char s[MAXSIZE]; (1)串联接:把两个串s1和s2首尾连接成一个新串s ,即:s=s1+s2。 int StrConcat1(s1,s2,s) char s1[],s2[],s[]; { int i=0 , j, len1, len2; len1= StrLength(s1); len2= StrLength(s2) if (len1+ len2MAXSIZE-1) return 0 ; /* s长度不够*/ j=0; while(s1[j]!=’\0’) { s[i]=s1[j];i++; j++; } j=0; while(s2[j]!=’\0’) { s[i]=s2[j];i++; j++; } s[i]=’\0’; return 1; } (2)子串 int StrSub (char *t, char *s, int i, int len) /* 用t返回串s中第个i字符开始的长度为len 的子串1≤i≤串长*/ { int slen; slen=StrLength(s); if ( i1 || islen || len0 || lenslen-i+1) { printf("参数不对"); return 0; } for (j=0; jlen; j++) t[j]=s[i+j-1]; t[j]=’\0’; return 1; } (3) 串比较 int StrComp(char *s1, char *s2) { int i=0; while (s1[i]==s2[i] s1[i]!=’\0’) i++; return (s1[i]-s2[i]); } 4.1.4串的应用举例 模式匹配 算法思想如下: 首先将s1与t1进行比较,若不同,就将s2与t1进行比较,..., 直到s的某一个字符si和t1相同,再将它们之后的字符进行比较, 若也相同,则如此继续往下比较,当s的某一个字符si与t的字符tj不同时,则s返回到本趟开始字符的下一个字符,即si-j+2,t返回到t1,继续开始下一趟的比较,重复上述过程。 若t中的字符全部比完,则说明本次匹配成功,本趟的起始位置是i-j+1或i-t[0],否则,匹配失败。 设主串s="ababcabcacbab",模

文档评论(0)

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

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

版权声明书
用户编号:6212135231000003

1亿VIP精品文档

相关文档