- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Chap 4 栈和队列 ?栈 ?队列 ?应用实例 栈和队列是两种重要的特殊线性表,是操作受限的线性表,有着广泛的应用。 §1 栈 ▲栈的定义和ADT ▲顺序栈 ▲链栈 ▲栈的简单应用举例 1.1 栈的定义和ADT 栈(Stack)是限定只在表尾进行元素的插入(入栈)与删除(出栈)操作的线性表。 表头端称为栈底(bottom), 表尾端称为栈顶(top)。 设有栈S=(a1,a2,…,an),则称a1为栈底元素,an为栈顶元素。元素入栈按a1,a2,…,an的次序进行,而出栈的第一个元素为栈顶元素。因此,栈又称为后进先出线性表,简称LIFO(last in first out)结构。 栈的ADT定义: ADT Stack is DataObject: D={ ai | ai∈DataType, i=1,2, …,n, n≥0 } Relation: R={ai,ai-1 | ai-1,ai∈D, i=1,2, …,n } 约定an为栈顶,a1为栈底。 Operation: InitStack 功能:栈初始化,构造一个空栈。 DestroyStack 功能:销毁栈 ClearStack 功能:清除栈元素 StackEmpty 功能:判定空栈 StackLength 功能:取栈的长度 GetTop 功能:读取栈顶元素 Push 功能:新元素入栈 Pop 功能:栈顶元素出栈,即删除栈顶元素 Traverse 功能:栈遍历 End Stack 1.2 顺序栈 栈的实现与线性表类似,有两种方法: 顺序栈 链栈 顺序栈的存储映象与线性表相同,用一个一维数组定义,不同的主要是实现各种栈操作的算法。 1.2.1 顺序栈的C++实现 顺序栈类的声明: template typename ElemType class SeqStack{ private: ElemType *stack; int maxSize; int top; //栈顶位置 public: 栈操作的成员函数原型声明 }; 1.2.2 顺序栈基本操作的算法 算法4.1 InitStack/SeqStack 功能:按默认值或给定要求动态分配存储空间并初始化,即构造一个空栈。 在类中初始化工作可由构造函数实现。 void InitStack ( int s) { maxSize=s; stack=new ElemType[maxSize]; //为顺序栈动态分配存储区 if(stack==NULL) exit(OVERFLOW); top=0; //置空栈 } 算法4.2 DestoryStack功能:销毁,即回收该栈的存储空间 void DestoryStack () { delete []stack; } 在类中栈的销毁工作可由析构函数完成。 算法4.3 ClearStack功能:清除表中的所有元素 void ClearStack () { top=0; } 算法4.4 StackEmpty功能:若为空表返回TRUE bool StackEmpty() { return top==0; } 算法4.5 Push功能:新元素入栈 bool Push(ElemType e) { if(top==maxSize) return FALSE; stack[top+1]=e; //新元素入栈顶 top++; return TRUE; } 算法4.6 Pop功能:栈顶元素出栈 bool Pop(ElemType e) { if(top1) return FALSE; e=stack[top]; top--; return TRUE; } 算法4.7 GetTop功能:读取栈顶元素 bool GetTop(ElemType e) { if(top1) return FALSE; e=stack[top]; return TRUE; } 算法4.8 Traverse功能:栈遍历 void Traverse() { for(i=top;i0;
您可能关注的文档
最近下载
- 兽医产科学(鞠辉明)第十章 分娩期疾病.pdf VIP
- 2025年济南市中考英语试题卷(含答案解析).docx
- 微观经济学:现代观点.ppt
- 2025年蜀道投资集团有限责任公司人员招聘笔试备考题库及答案解析.docx VIP
- 新12J07 室外工程标准图集.pdf VIP
- 部编版语文六年级上册全册教学设计(教案).pdf VIP
- 古建筑亮化工程施工方案(3篇).docx VIP
- GB∕T22081-2024《网络安全技术信息安全控制》之2:“5组织控制-5.2信息安全角色和责任”专业深度解读和应用指导材料(雷泽佳编制-2025A0).pdf VIP
- MAPGIS67教程(制图详细步骤讲解.doc VIP
- CPA经济法必背考点.pdf VIP
文档评论(0)