串的基本操作演示.docVIP

  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文档。上传文档
查看更多
串的基本操作演示

附录有原程序清单。 3.4串的基本操作演示 需求分析 1.在教科书4.2.2节用堆分配存储表示实现HString串类型的最小操作子集基础上,实现串抽象数据类型的其余基本操作,参数合法性检查必须严格。 2.本演示系统是一个命令解释程序,循环往复的处理用户输入的每一条命令,直至终止程序的命令为止。 3. 将串头表改为用单链表实现,并支持串名,串名存于串头表中,串名字符不超过6个(选做)。 4. 对于命令的格式做严格的语法检查,使系统可以处理正确的命令,也可以处理错误的命令。(选做) 二、概要设计 1.串的抽象数据类型结构: ADT String{ 数据对象:D={ai| ai∈charcaterset,i=1,2,…,n,n=0} 数据关系:R1={ai-1,ai|ai-1,ai∈D, i=1,2,…,n} 基本操作: Assign( T ,chars ) 初始条件:chars是字符串常量。 操作结果:生成一个其值等于chars的串T。 StrCopy( T , S )     初始条件:串S存在。     操作结果:由S串复制得到串T。       StrEmpty( S ) 初始条件:串S 存在。 操作结果:若串为空串,返回TRUE,否则返回FALSE。StrCompare( S , T ) 初始条件:S和T是已存在。 操作结果:比较其值,若ST,返回值0,若S=T,返回值=0,若ST,返回值0。 StrLength( S ) 初始条件:S是已存在。 操作结果:返回该串的长度。 ClearString ( S ) 初始条件:S是已存在。 操作结果:将串S清为空串。 Concat( T , S1 , S2 ) 初始条件:S1和S2是已存在。 操作结果:由S1和S2联接成新串T。 SubString( Sub , S , int pos , int len ) 初始条件:S是已存在,1≤pos≤StrLength(S)且0≤len≤StrLength(S)-pos+1。 操作结果:用Sub返回串的第pos个字符起长度为len的子串。 Index( S , T , pos ) 初始条件:S和T已存在,T是非空串,1≤Spos≤StrLength(S)。 操作结果:若主串S中存在和串T相同的子串,则返回它在主串中第pos个字符之后第一次出现的位置;否则返回函数值为0。 Replace( S , T , V ) 初始条件:串S,T和V存在,T是非空串。 操作结果:用V替换主串S中出现的所有和T相同的不重叠的子串。 StrInsert( S , pos ,T ) 初始条件:串S,T存在,1≤pos≤StrLength(S)。 操作结果:在串S第pos个字符前插入串T。 StrDelete( S ,pos , len ) 初始条件:串S存在,1≤Spos≤StrLength(S)-len+1 操作结果:从串S中删除第pos个字符长度为len的子串。 DestroyString( S ) 初始条件:串S存在。 操作结果:串S被销毁。 }ADT String 2. 本程序包括三个模块: (1)主程序模块,主函数为: void main(){ 文件初始化 do{ 输入命令 命令分析 做相应的串操作 }while(没有接收到退出命令) } (2)命令分析函数模块----主要是对命令行的提取,得到命令和各参数。 (3)串的单元模块----主要是实现串的抽象数据类型。 各个模块之间的调用关系如下: 主程序模块 串的模块 命令分析模块 三、详细设计 1. 串类型 #define TRUE 1 #define FALSE 0 typedef int Status; typedef struct { //字符串储存结构 char *ch; int le

文档评论(0)

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

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

1亿VIP精品文档

相关文档