九江学院《数据结构》第03章 栈与队列.pptVIP

九江学院《数据结构》第03章 栈与队列.ppt

  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文档。上传文档
查看更多
九江学院《数据结构》第03章 栈与队列

第三章 栈和队列 3.1 栈 3.2 栈的应用举例 3.3 队列 空栈:没有元素的栈 栈的特性: 先进后出(LIFO),即只能在末端(栈顶)进行插、删的操作 栈的存储结构 顺序栈 利用一组地址连续的存储单元依次存放自栈底到栈顶的数据元素,一般用一维数组表示 必须附设一个位置指针top(栈顶指针)来动态地指示栈顶元素在顺序栈中的位置 链栈 采用链表作为存储结构实现的 必须设置一个栈顶指针永远指向栈顶 顺序栈的共享 为两个栈申请一个共享的一维数组空间S[M] 将两个栈的栈底分别放在一维数组的两端,分别是0,M-1 共享栈的结构定义 共享栈的操作 共享栈的进栈操作 共享栈的出栈操作 Int Match(c1,c2) {if ((c1==‘(‘c2==‘)’)|| (c1==‘[‘c2==‘]’)|| (c1==‘{‘c2==‘}’)) return(1); else return(0); } case ‘)’: case ‘]’: case ‘}’: if(IsEmpty(S)) {printf(“ERROR!”);return(0);} else {GetTop(S,ch); if(Match(ch,str[i])) Pop(S,ch); else {printf(“ERROR!”);return(0);}}} if(IsEmpty(S)) printf(“Right!\n”); else printf(“ERROR!\n”);} 在用高级语言编写的源程序中,存在着大量的表 达式,那么,计算机是如何处理表达式的呢?对于编译 系统来说,利用栈,根据表达式的运算顺序把表达式翻 译成一个线性序列(如(B+C)/(A-D)?BC+AD-/), 然后再转换成指令序列进行求值。而对于解释系统而 言,是对表达式直接进行运算,即根据表达式的运算顺 序对它边解释边求值。 确定运算顺序就是考虑表达式中各运算符的优先级,优先级大的运算符应优先处理。 栈具有记忆的功能,把表达式中已经扫描到但暂时还不能进行的运算记录在栈中。 下面以解释系统的处理过程为例来说明表达式的计算过程。 后缀表达式也称为逆波兰式波兰表示法(也称为前缀表达式)是由波兰逻辑学家(Lukasiewicz)提出的,其特点是将运算符置于运算对象的前面,如a+b表示为 +ab; 中缀表达式“3*2^(4+2*2-1*3)-5 ” :“32422*+13*-^*5-” 中缀表达式A*B + C/D;的后缀表达式为AB*CD/+ 中缀表达式转换成后缀表达式与中缀表达式的计算类似,举例如下: 计算一个后缀表达式,算法上比计算一个中缀表达式简单的多。这是因为表达式中即无括号又无优先级的约束。具体做法:只使用一个对象栈,当从左向右扫描表达式时,每遇到一个操作数就送入栈中保存,每遇到一个运算符就从栈中取出两个操作数进行当前的计算,然后把结果再入栈,直到整个表达式结束,这时送入栈顶的值就是结果。 中缀表达式转换成后缀表达式: 将中缀表达式转化为后缀表达示和前述对中缀表达式求值的方法完全类似,但只需要运算符栈,遇到运算对象时直接放后缀表达式的存储区,假设中缀表达式本身合法且在字符数组A中,转换后的后缀表达式存储在字符数组B中。具体做法:遇到运算对象顺序向存储后缀表达式的B数组中存放,遇到运算符时类似于中缀表达式求值时对运算符的处理过程,但运算符出栈后不是进行相应的运算,而是将其送入B中存放。 队列的主要运算 设置一个空队列; 插入一个新的队尾元素,称为进队; 删除队头元素,称为出队; 读取队头元素;等 队列的存储结构 (1)顺序存储结构 队列的类型定义: #define MAXSIZE 50 typedef struct {QueueElementType elem [MAXSIZE]; int front;int rear; }SeqQueue; 和栈类似,队列中亦有上溢和下溢现象。 此外,顺序队列中还存在“假上溢”(假溢出) 现象。因为在入队和出队的操作中,头尾指针 只增加不减小,致使被删除元素的空间永远无 法重新利用。因此,尽管队列中实际的元素个 数远远小于向量空间的规模,但也可能由于尾 指针巳超出向量空间的上界而不能做入队操作 。该现象称为假上溢。 区分队列空与满另一种方法 少用一个元素的空间,约定入队前,测试 尾指针在循环意义下加1后是否等于头指针,若 相等则认为队满(注意:rear所指的单元始终 为空); (6)取头元素 queuedatatype qu

文档评论(0)

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

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

1亿VIP精品文档

相关文档