(五)顺序栈

最后更新于:2022-04-01 09:40:12

### 定义 只能在表的一端(栈顶)进行插入和删除运算的线性表 ### 逻辑结构 一对一关系 ### 存储结构 用顺序栈或链栈存储均可,但以顺序栈更常见 ![栈示意图](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-25_56ce7d1f37242.jpg "") ### 运算规则 只能从栈顶运算,且访问结点时依照后进先出(LIFO)或后进后出(FILO)的原则 ### 实现方法 关键是编写入栈和出栈函数,具体实现依顺序栈或链栈的不同而不同 ### 基本操作 - 入栈 - 出栈 - 读栈顶元素值 - 建栈 - 判断栈满 - 栈空 ### 栈与一般线性表的区别 栈是一种特殊的线性表,它只能在表的一端(栈顶)进行插入或删除运算 | ** | 一般线性 表 | 栈 | |-----|-----|-----| | 逻辑结构 | 一对一 | 一对一 | | 存储结构 | 顺序表、链表 | 顺序栈、链栈 | | 运算规则 | 随机、顺序存储 | 后进先出 | ### 它们之间在于运算规则不同 ![栈顶栈底](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-25_56ce7d1f5060d.jpg "") > 我们在平常的程序设计中,如果需要按照保存数据时相反的顺序来使用数据,可以利用栈来实现。 ### 顺序栈的表示 ~~~ #define MAXSIZE 100 typedef struct { SElemType *base; SElemType *top; int stacksize; }SqStack; ~~~ stacksize 指示栈的最大容量;base为栈底指针,它始终指向栈底位置,若base的值为NULL,则表明栈结构不存在;top为栈顶指针,其初值指向栈底,即top=base可作为栈空的标记。每当插入新的栈顶元素时,指针top增加1;删除栈顶元素时,指针top减1.因此,非空栈中的栈顶指针始终在栈顶元素的下一个位置上。 base == top 是栈空的重要标志 ### 栈满时的处理方法 1. 报错,返回操作系统。 1. 分更大的空间,作为栈的存储空间,将原栈的内容移入新栈。 ### 初始化 ![顺序栈](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-25_56ce7d1f634ce.jpg "") (1)分配空间并检查空间是否分配失败,若失败则返回错误 (2)设置栈底和栈顶指针 S.top = S.base; (3)设置栈大小 【算法描述】 ~~~ Status InitStack(SqStack &S) { S.base=new SElemType[MAXSIZE]; if(!S.base) return OVERFLOW; S.top=S.base; S.stackSize=MAXSIZE; return OK; } ~~~ ### 判断顺序栈是否为空 ~~~ bool StackEmpty(SqStack S) { if(S.top == S.base) return true; else return false; } ~~~ ### 求顺序栈的长度 ~~~ int StackLength(SqStack S) { return S.top-S.base; } ~~~ ### 清空顺序栈 ~~~ Status ClearStack(SqStack S) { if(S.base)S.top = S.base; return OK; } ~~~ ### 销毁顺序栈 ~~~ Status DestroyStack(SqStack &S) { if(S.base) { delete S.base; S.stacksize = 0; S.base = S.top =NULL; } return OK; } ~~~ ### 顺序栈进栈 (1)判断是否栈满,若满则出错 (2)元素e压入栈顶 (3)栈顶指针加1 ~~~ Status Push(SqStack &S,SElemType e) { if(S.top - S.base == S.stacksize)//栈满 return ERROR; *S.top=e; S.top++; return OK; } ~~~ ### 顺序栈出栈 (1)判断是否栈空。若空则出错 (2)获取栈顶元素e (3)栈顶指针减1 Status Pop(SqStack &S,SElemType &e) { if(S.top == S.base)//栈空 return ERROR; –S.top; e= *S.top; return OK; } ### 取顺序栈栈顶元素 判断是否为空栈,若为空则返回错误 否则通过栈顶指针获取栈顶元素 ~~~ Status GetTop(SqStack S,SElemType &e) { if(S.top == S.base) return ERROR;//栈空 e = *(S.top-1); return OK; } ~~~
';