数据结构——栈

目录

一、栈的定义与特性

(1)定义

(2)特性

二、栈的基本操作

三、顺序栈(栈的顺序存储结构)

1、顺序栈的类型定义

2、顺序栈基本操作的实现

四、栈的应用

一、栈的定义与特性

(1)定义

栈是一种插入操作与删除操作限制在同一端进行的特殊线性表

栈顶(top):进行插入与删除操作的一端

栈底(bottom):另一端

空栈:不含任意元素的栈

(2)特性

后进先出(LIFO---Last In First Out)

先进后出(FILO---First In Last Out)

二、栈的基本操作

设栈抽象数据类型为Stack,常用的基本操作有:

|-------|---------------------------|--------------------------|----------------------------------------------------|
| | 操作函数 | 初始条件 | 操作结果 |
| 初始化操作 | InitStack(&S) | 栈 S 不存在 | 构造一个初始空栈 S |
| 销毁操作 | destroyStack(&S) | 栈 S 已存在 | 将栈 S 销毁,释放栈的存储空间 |
| 判空操作 | stackIsEmpty(S) | 栈 S 已存在 | 判断栈 S 是否为空;若栈为空则返回TURE, 否则返回 FALSE |
| 清空操作 | clearStack(&S) | 栈 S 已存在 | 将栈 S 清空,变为空栈 |
| 入栈操作 | Push(&S, e) | 栈 S 已存在,e 为给定数据元素值 | 将给定值为 e 的元素入栈,即将 e 在栈 S 的栈顶端插入 |
| 出栈操作 | Pop(&S, &e) | 栈 S 已存在且非空 | 将栈 S 的栈顶元素出栈,即将栈顶元素删除,并通过 参数 e 返回出栈元素的值 |
| 取栈顶操作 | getTop(S, &e) | 栈 S 已存在且非空 | 取栈 S 的栈顶元素的值,将其值通过参数 e 返回 |
| 求栈长操作 | stackLength(S) | 栈 S 已存在 | 求栈 S 的长度,即栈中的元素个数;当栈 S非空时, 函数返回该栈的长度;而当栈 S为空时则返回 0 |
| 遍历操作 | stackTraverse(S, visit()) | 栈 S 已存在; visit()为元素的访问函数 | 依照从栈底到栈顶的顺序依次访问栈 S 的元素,且每个元素只被访问一次 |

三、顺序栈(栈的顺序存储结构)

1、顺序栈的类型定义

#define StackSpaceIncr 20

struct{

SElemType *base;

int top;

int stackSize;

}SqStack ;

2、顺序栈基本操作的实现

(1)初始化操作 InitSqStack(&S, InitSize)

Status InitSqStack(SqStack &S, int InitSize)
{

     S.base = (SElemType *)malloc(InitSize * sizeof(SElemType) );

     if(!S.base) return OVERFLOW;    

     S.stackSize = InitSize;

     S.top = 0;

     return OK;

}

(2)判空操作、清空操作与求栈长操作

Status stackIsEmpty(SqStack S)
{

      if( !S.top ) return TRUE;

      else return FALSE;

}

void clearStack(SqStack &S)
{

      S.top=0;

}

int stackLength(SqStack S)
{

      return S.top;

}

(3)入栈操作 Push(&S, e)

Status Push(SqStack &S, SElemType e)
{
    SElemType *newBase;
    if( S.top==S.stackSize )
    {   
        newBase=(SElemType*)realloc( S.base,    

        (S.stackSize+StackSpaceIncr)* sizeof(SElemType) );

         if(!newBase) return OVERFLOW;  

         S.base=newBase;

         S.stackSize+=StackSpaceIncr;         

     }

     S.base[S.top] = e;               

     S.top++;                            

     return OK;

}

(4)出栈操作 Pop(&S, &e)

Status Pop(SqStack &S, SElemType &e)
{

      if( !S.top ) return ERROR;    

      S.top-- ;    

      e=S.base[S.top];                       

      return OK;

}

四、栈的应用

1.简单的行编辑程序

2.迷宫问题

相关推荐
每天减 1/5kg几秒前
创建者——建造者模式
开发语言·python·建造者模式
小赖同学啊1 分钟前
物联网 智慧水库管理系统中集成无人机巡逻和隔空喊话
物联网·无人机
码道功成3 分钟前
快速创建基于Scala的flink开发项目
开发语言·flink·scala
New_Teen7 分钟前
C++小课堂——变量的声明,赋值和初始化
开发语言·c++·笔记·学习
练习&两年半17 分钟前
C语言:51单片机 程序设计基础
c语言·开发语言·单片机·51单片机
橘猫云计算机设计28 分钟前
基于微信小程序的疫情互助平台(源码+lw+部署文档+讲解),源码可白嫖!
java·大数据·开发语言·spring boot·微信小程序·小程序·汽车
无世世1 小时前
【Java从入门到起飞】面向对象编程(基础)
java·开发语言
李白同学1 小时前
C++:类和对象(下篇)
开发语言·c++
修昔底德1 小时前
费曼学习法12 - 告别 Excel!用 Python Pandas 开启数据分析高效之路 (Pandas 入门篇)
人工智能·python·学习·excel·pandas
li158172604142 小时前
T41LQ专为人工智能物联网(AIoT)应用设计,适用于智能安防、智能家居、机器视觉等领域 软硬件资料+样品测试
人工智能·物联网·智能家居