- 1、本文档共30页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构讲义第3章节
第三章 栈和队列 栈和队列是两种重要的数据结构。 从结构特性角度看,栈和对列也是线性表,其特殊性在于它们的基本操作是线性表的子集,是操作受限的线性表,可称为限定性的数据结构。 从数据类型角度看,其操作规则与线性表大不相同,是完全不同于线性表的抽象数据类型。 第一节 栈 栈的表示与实现 顺序栈操作的实现 顺序栈操作的实现 顺序栈操作的实现 顺序栈操作的实现 链式栈的实现 第二节 栈的应用 栈的应用 栈的应用—表达式求值 栈的应用—表达式求值 栈的应用—表达式求值 栈的应用—表达式求值 第三节 栈与递归的实现 栈与递归的实现 第四节 队列 队列的链式表示及实现 链队列基本操作 链队列基本操作 链队列基本操作 队列的顺序表示及实现 队列的顺序表示及实现 队列的顺序表示及实现 循环队列 循环队列算法 循环队列算法 循环队列算法 队列的应用 作业 * 一、栈的定义 栈是限定在表的一端进行插入和删除操作的线性表。 插入:称为进栈(或压栈)。 删除:称为出栈(或退栈)。 栈顶(top):允许进行插入和删除操作的一端。 栈底(bottom):不允许插入和删除操作的一端。 基本操作: Initstack(s): 栈初始化 Destroystack(s):撤消栈 Clearstack(s):置栈空 Stackempty(s) :判栈空 Stacklength(S):求栈中元素个数 Gettop(S,e): 取栈顶元素 Push(S,e): 入栈 Pop(S,e): 出栈 特点:后进先出----LIFO Last In First Out 栈底 … an a2 a1 栈顶 三、栈的顺序存储结构----顺序栈 利用一组地址连续的存储单元依次存放从栈底到栈顶的数据元素。 顺序栈存储结构定义: #define STACK_INIT_SIZE 100 //存储空间初始分配量; #define STACKINCREMENT 10 //存储空间分配增量 typedef struct { SElemType *base; SElemType *top; int stacksize; }SqStack; Base指向存储空间开始地址,top指示栈顶当前位置。 若栈空间未分配,则base为NULL; top==base:栈空 top-base==stachsize:栈满 元素进栈:在top位置插入元素,top增1 元素出栈:top减1。 top指针始终指向栈顶元素的下一个位置 。 1、栈初始化:分配初始存储空间,初始化各变量。 Status Initstack(Sqstack s) { s.base=(SElemType *) malloc(STACK_INIT_SIZE*sizeof(SElemType)); if(!b.base) exit(OVERFLOW); s.top=s.base; s.stacksize= STACK_INIT_SIZE; return Ok; } 2、撤消栈:释放栈空间。 status Destroystack(SqStack s) { if(s.base) { free(s.base); s.base=NULL;return OK;} return ERROR; } 3、置栈空:将栈设置成空栈。 status Clearstack(SqStack s) { if(s.base) { s.top=s.base;return OK;} return ERROR; } 4、取栈顶元素:返回栈顶元素的值。 status GetTop(SqStack s,SElemType e) { if(s.top==s.base) return ERROR; e=*(s.top-1); return OK } 5、入栈操作:把元素压入栈中。 status Push(SqStack s,SElemType e)
您可能关注的文档
- 高考物理-物理2、图像问题的处理方法答题技巧〔不看后悔〕.ppt
- 高考英语全面复习22.ppt
- 高考英语全面复习18.ppt
- 高考政治1轮复习课件:我国政府受人民的监督.ppt
- 高考英语全面复习3.ppt
- 高考英语全面复习5.ppt
- 高科GK217产品简介—OK版0629.ppt
- 高考英语写作经典3段式.ppt
- 高考英语全面复习9.ppt
- 高考英语全面复习23.ppt
- 中考语文总复习语文知识及应用专题5仿写修辞含句子理解市赛课公开课一等奖省课获奖课件.pptx
- 湖南文艺版(2024)新教材一年级音乐下册第二课《藏猫猫》精品课件.pptx
- 湖南文艺版(2024)新教材一年级音乐下册第三课《我向国旗敬个礼》精品课件.pptx
- 高中生物第四章生物的变异本章知识体系构建全国公开课一等奖百校联赛微课赛课特等奖课件.pptx
- 整数指数幂市公开课一等奖省赛课微课金奖课件.pptx
- 一年级音乐上册第二单元你早全国公开课一等奖百校联赛微课赛课特等奖课件.pptx
- 八年级数学上册第二章实数27二次根式第四课时习题省公开课一等奖新课获奖课件.pptx
- 九年级物理全册11简单电路习题全国公开课一等奖百校联赛微课赛课特等奖课件.pptx
- 八年级语文下册第五单元19邹忌讽齐王纳谏省公开课一等奖新课获奖课件.pptx
- 2024年秋季新人教PEP版3年级上册英语全册教学课件 (2).pptx
文档评论(0)