- 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)
文档评论(0)