- 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 串及其操作 4.2 串的存储结构 4.3 串的基本运算实现 4.4 串的模式匹配运算 习题 在非数值处理的应用领域中,字符串的应用非常广泛。如编辑器(Edit、Word本质上是字符串处理)、信息检索(字符串比较)等。 实际上,编写数值计算程序的机会很有限。从发明计算机的思路来说,其目的是为了模拟人类的对信息的逻辑处理方法,而数值计算仅仅是一种逻辑思路的标准化。 现今我们使用的计算机的硬件结构主要反映数值计算的需要的,因此,在处理字符串数据时比处理整数和浮点数要复杂的多。而且,在不同类型的应用中,所处理的字符串具有不同的特点,要有效地实现字符串的处理,就必须根据具体情况使用合适的存储结构。下面将讨论字符串的一些处理方法和字符串的几种不同的存储结构。 4.1 串及其操作 4.1.1 串的逻辑结构 定义:串(字符串),是由零个或多个字符组成的有限序列。一般记作: s=″a0a1…an-2an-1″ (n≥0) s是串的名。 双引号括起来是是串的值。 n为串的长度。 空串为零个字符,n=0。 子串为串中任意个连续的字符组成的子序列。 位置为字符在序列中的序号。为字符在串中的称作。 子串位置以子串的第一个字符在主串中的位置来表示。 举例:a=″This is a string″ 串长=16 b=″string″串长=6 ,是a的子串,在a串的位置是10 c=″ ″串长=2,的空格串,它不是a和b的子串。 串的集合定义: 设string=(D,R)是一个数据结构,其中 D={a0,a1,…,an-1} 为字符元素的集合,i=0,…,n-1 ,并且n≥0。 R={ai-1,ai|ai-1,ai∈D,i=1,2,…,n-1} R为上元素的关系集合 则称 string是一个字符串。字符串与线性表的区别是 它的数据对象为字符集。 4.1.2 串的基本运算 (1)赋值操作assign(s,t)。将t的值赋给s。 (2)串相等判断equal(s,t)函数。若s串与t串相等,则函数返回1,否则函数将返回0。 (3)串的联接操作concat(s,t)函数。将s串和t串联接成一个串,新生成的串是s串在前,而t串紧接s串的尾部。 例如,设a=″data ″, b=″structure″,执行concat(a,b), 新生成的串是″data structure″。 串的联接不满足交换律:concat(s,t)!=concat(t,s) ; 串的联接满足结合律: concat(s1,concat(s2,s3))=concat(s1,s2,s3) 其运算结果是将这3个串的值依次首尾相接得到一个新串。 (4)求长度length(s)函数。其函数值为串s中字符的个数。 (5)求子串sub(s,start,len,t)。若 0≤startlength(s) 0≤len≤length(s)-start则t中值为从串s中第start个字符起,长度为len的字符序列,并且函数返回值为1;否则函数返回值为0。 例如,s=″data structure″, sub(s,5,5,t), 则 t=″struc″。 (6)子串定位index(s,t)函数。若在主串s中存在和t相等的子串,则函数值为s中第一个这样的子串在主串s中的位置,否则函数值为-1。注意,在此t不能是个空串。例如,s=″data structure″, t=″ru″, 则index(s,t)=7。 (7)替换replace(s,t,v)。操作结果是以串v替换串s中出现的所有和非空子串t相同的不重叠子串。 4.2 串的存储结构 在程序执行的过程中,串的值可变。所以,与在程序出现的其他类型的变量一样,给要处理的串赋一个变量名,这样在对串进行操作时,可以通过变量名访其值。 串的存储结构有两种形式: 一种是将串设计成一种结构类型,串是字符型的数组,从串名可直接访问到串值,串值的存储分配是在编译时完成; 一种是串值的存储分配是在程序运行时完成,在串名和串值之间需
文档评论(0)