线性表_栈与队列_2012_1.pptVIP

  1. 1、本文档共82页,可阅读全部内容。
  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文档。上传文档
查看更多
线性表_栈与队列_2012_1

2.4 串和数组 串 串(String)是由零个或多个字符组成的有限序列。 一般记为: S=a1 a2 ... an (n≥0) 零个字符的串称为空串(null string),长度为零。 串名 串的长度 基本概念 串中任意个连续字符组成的子序列称该串的子串。 包含子串的串相应地称为主串。 称字符在序列中的序号为该字符在串中的位置。 子串在主串中的位置则以子串的第一个字符在主串中的位置来表示。 当两个串的长度相等,且各个对应位置上的字符都相等时,称两个串相等。 例2-10 串名为A、B、C、D的四个串如下: A=very good; B= ; C=; D=good; 注意区分空格串、空串、字串、主串 等基本概念。 串的基本操作 (1) ASSIGN(s,t)和CREAT(s,ss)赋值操作。 将串t或字符序列ss的值赋给s。 (2)EQUAL(s,t)判等函数。若s和t相等,则返回函数值“true”,否则返回函数值“false”。 (3)LENGTH(s)求串长函数。其返回值是串s中字符的个数。 (4) SUBSTR(s,start,len) 求子串函数,表示从串s中的第start个字符开始,取出 len 个字符构成一个新的串。其中,1≤start≤LENGTH(s),且1≤len≤LENGTH(s) -start+1。 (5) CONCAT(s1,s2) 联接函数。将s2的串值紧接着放在s1串值的末尾而组成一个新的串,新的串值名为s1。 如 s1=‘very’,s2=‘good’,则 CONCAT(s1,s2)=very good。 (6) INDEX(s1,s2)定位函数。若在主串s1中存在与s2相等的子串,则函数值为s1中第一个与s2相等的子串在主串s1中的位置;否则函数值为0。 如 INDEX(abbcbc,bc)=3 INDEX(abcbc,ac)=0 (7) REPLACE(s1,s2,s3)置换操作。操作结果是用串s3替换s1中所有与串s2相等且不重叠的子串。如 设s=‘bbabbabba’则REPLACE(s,‘ab’,‘c’)后,串s变为:S=bbcbcba。 a1, a2, a3, a4, ..., an 删除端 插入端 队头front 队尾rear 队列—结构 FIFO (First In First Out) 队头、队尾均是浮动的 队列—特点 为什么要研究队列? 离散事件的模拟(模拟事件发生的先后顺序); 操作系统中的作业调度(一个CPU执行多个作业); 简化程序设计。 队列的顺序存储结构 typedef struct { datatype data[maxsize]; int front,rear; } sequeue; /* 顺序队列的类型 */ sequeue ?sq /* sq 是顺序队列的指针 */ 规定: 头指针front总是指向当前队头元素的前一个位 置,尾指针rear指向当前队尾元素的位置。 队列的基本操作 初始化队列。 判定队列是否为空。 入队操作。 出队操作。 读取队列的队头元素。 D C B A sq-rear=-1 sq-front=-1 sq-rear=0 sq-rear=1 sq-rear=2 sq-rear=3 sq-rear=-1 sq-front=-1 空队列 A、B、C、D相继入队 sq-front=0 sq-front=1 sq-front=2 sq-rear=3 sq-front=-1 C D B A sq-front=3 A、B、C、D相继出队 E F sq-front=3 sq-rear=5 E、F相继入队 队列的运算总结 入队运算 sq-rear++; /* 尾指针加1 */ sq-data[sq-rear]=x; /* x入队 */ 出队运算 sq-front++; /* 头指针加1 */ 总结队列为空与队列为满的条件 E F sq-front=3 sq-rear=5 E、F相继入队 假溢出现象 请想想如何解决 假溢出问题? 循环队列示意图 循环队列 队头指针的后移 if (sq-front + 1 == maxsize) sq-front = 0

文档评论(0)

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

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

1亿VIP精品文档

相关文档