数据结构和算法4.pptVIP

  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文档。上传文档
查看更多
 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;

文档评论(0)

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

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

1亿VIP精品文档

相关文档