- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
SUN数据结构第4章串(第11讲)
* 第 4 章 串 孙丽云 * 4.1 串及其基本运算 4.1.1 串的基本概念 串(或字符串)是由零个或多个字符组成的有限序列。一般记作:s=〃c0c1c2…cn-1〃 (n≥0) 其中:s为串名; 用双引号括起来的字符序列是串的值; 字符串字符的数目n称为串的长度。 例:s=“computer”分别指出其串名、串值及串的长度。 串是一种特殊的线性表,它的数据对象是字符集合。 注意 1、空串和空格串的区别: 零个字符的串称为空串,通常以两个相邻的双引号来表示空串。如:s=“”,它的长度为零; 仅由空格组成的的串称为空格串。 如:s=〃 〃,它的长度为空格的个数。 2、若串中含有空格,在计算串长时,空格应计入串的长度中 如:s=“I’m a student〃的长度为13。 4.1.1 串的基本概念 两个串相等的条件: (1)两个串的长度相等; (2)各对应位置上的字符都相同。 串中任意个连续字符组成的序列称为该串的子串。包含子串的串被称为主串。 如,“com”、“om”、“a”和“man”都是“commander”的子串。 4.1.1 串的基本概念 特别:空串是任意串的子串,任意串是其自身的子串。 判断:长度相等且包含相同字符的两个字符串必定相等。 × 子串在主串中的位置是指子串在主串中首次出现时的该子串的首字符对应的主串中的序号。 例如: (1)子串“man”在主串“commander”中的位置为4。 (2)设A和B分别为 A=“This is a string” B=“is” 求子串在主串中的位置。 4.1.1 串的基本概念 3 串是一种简单的数据结构,它的逻辑结构与线性表十分相似,区别仅在于串的数据对象是字符集。 串的基本运算与线性表的基本运算有很大差别。通常在串的基本运算中,以“串的整体”作为操作对象;而在线性表的基本运算中,大多以“单个元素”作为操作对象。 4.1.2 串的基本运算 4.1.2 串的基本运算 1.Strassign(s,chars) 功能:赋值运算。将串常量chars的值赋给串变量s。 例如:执行strassign(s,“abcd”)运算之后,s的值为“abcd”。 2.Assign(s,t) 功能:赋值运算。将串变量t的值赋给串变量s。 例如:t=abcd,则执行Assign(s,t)运算之后,s的值为abcd。 4.1.2 串的基本运算 3.Equal(s,t) 功能:判相等运算。若s与t的值相等则运算结果为1,否则为0。 4.Length (s) 功能:求串长运算。求串 s序列中字符的个数,即串的长度。 5.Concat (s,t) 功能:联接运算。将串t的第一个字符紧接在串 s的最后一个字符之后,联接得到一个新串。例如s=man,t=kind,则执行Concat (s,t)运算后得到的新串为mankind。 6.Insert(s,pos, t) 功能:插入运算,当1≤pos ≤ Length (s)+1时,在串 s的第 pos 个字符之前插入串 t。 7.Delete(s,pos,len) 功能:删除运算。当1≤pos≤Length(s)且0≤len≤Length (s)-pos+1时,从串s中删去从第pos个字符起长度为len的子串。 8.Replace(s,pos,len,t) 功能:置换运算。当1≤pos≤Length (s)且0≤len≤Length(s)-pos+1时,用串t替换串s中从第 pos 个字符起长度为len的子串。 4.1.2 串的基本运算 例:已知s=“(xyz)+*”,t=“(x+z)*y”。试利用联接、求子串和置换等基本运算,将s转换为t。 void trans() { char a[10]=“(xyz)+*”; string s,t,s1,s2,s3,s4,s5; Strassign(s,a); s1=SubStr(s,3,1); s2=SubStr(s,6,1); s3=SubStr(s,7,1); s4=SubStr(Replace(s,3,1,s2),1,5); s5=concat(s4,s3); t=concat(s5,s1); } s1=“y” s2=“+” s3=“*” 练习 设 S1 = “Data Structure Course”, S2 = “Structure”,S3 =“Base”,求:(1)Length(S1); (2)Insert(S1,5,S3); (3)Delete(S1,6,9);(4)SubStr(S1,6,9); (5)Index(S1,S2); 21 DataBase Structure Course Data Course Stru
您可能关注的文档
最近下载
- 2024年新人教道德与法治一年级上册全册教学课件(新版教材).pptx
- 一种去除皮革醛类VOCs的方法.pdf VIP
- 党员发展对象思想汇报.doc VIP
- 07 文言文四类实词积累方法(文言文阅读)-2026年高考语文一轮复习之古诗文专题课件(全国通用).pptx
- 网御网络审计系统V3.0用户使用手册.doc.pdf VIP
- 泥水工劳务承包合同(2024版).docx VIP
- 初三英语完形填空十篇(含答案).docx VIP
- 球磨机设计完整版.doc VIP
- 2024年《关于加快经济社会发展全面绿色转型的意见》学习解读课件.pptx VIP
- DB44_T 2693-2025电化学储能电站安全管控技术规范.pdf VIP
文档评论(0)