0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

详解数据结构中栈的定义和操作

OSC开源社区 来源:OSCHINA 社区 2023-04-27 14:04 次阅读

1.栈的定义

栈(stack):是只允许在一端进行插入或者删除操作的线性表(即后进先出,大概可以理解为吃饱了吐出来)

空栈:不含元素的空标配

栈顶:表尾端

栈底:表头端

dfc737aa-e4c0-11ed-ab56-dac502259ad0.png

进栈顺序:a1->a2->a3->a4->a5

出栈顺序:a5->a4-a3->a2->a1

2. 对比线性表和栈基本操作

2.1 线性表的基本操作

InitList (&L): 初始化表。构造一个空的线性表 L,分配内存空间

DestoryList (&L): 销毁操作。销毁线性表,并且释放线性表 L 所占用的空间

ListInsert (&L,i,e): 插入操作,在表 L 中的第 i 个位置上插入指定元素 e

ListDelete (&L,i,e): 删除操作,删除表 L 中的第 i 个位置的元素,并且用 e 返回删除元素的值

LocateElem (L,e): 按值查找操作,在表 L 中查找具有给定关键字值的元素

GetElem (L,i): 按位查找操作,获取表 L 中第 i 个位置的元素的值

2.2 栈的基本操作

InitStack (&S): 初始化栈,构造一个空栈 S,分配内存空间

DestoryStack (&S): 销毁栈,销毁并释放栈 S 所占用的内存空间

Push (&S,x): 进栈,若栈 S 未满,则将 x 加入使之成为新的栈顶

Pop (&S,&x): 出栈,若栈 S 非空,则弹出栈顶元素,并用 x 返回

GetTop (S,&x): 读栈顶元素,若栈 S 非空,则用 x 返回栈顶元素

其他常见操作:StackEmpty (S): 判断一个栈 S 是否为空,若 S 为空,则返回 true,否则返回 false

3. 顺序栈

dfe74b12-e4c0-11ed-ab56-dac502259ad0.png

3.1 顺序栈的定义

#define MaxSize 10           //定义栈中元素的最大个数 
typedef struct{
 ElemType data[MaxSize];   //静态数组存放栈中的元素
    int top;      //栈顶指针
}SqStack;         //结构体重命名

声明一个顺序栈后就会在内存中分配一整片连续的空间,其中内存大小为:MaxSize*sizeof (ELemType)

void testStack(){
 SqStack S; //声明一个顺序栈
}

3.2 栈的初始化操作

由于栈顶指针 top 需要指向此时栈顶元素,所以让 top 指向 0 是不合理的,可以初始化让 top 指向 - 1; 判断一个栈是否为空,即判断 S.top 是否等于 - 1 初始化栈:

void Inittack(SqStack){
 SqStack S;   //声明一个顺序栈
 S.top=-1;
}

判断栈空:

bool StackEmpty(SqStack S){
    if(S.top==-1)      //栈空
        return true;
    else 
        return false;  //非空
}

3.3 进栈操作

分析:

判断栈是否为空

栈顶指针 + 1

新元素入栈

bool Push(SqStack &S,ElemType x){
 if(S.top==NaxSize-1)
        return false;
 S.top+=1;
 S.data[S.top]=x;
        return true;
}

3.4 出栈操作

bool Push(SqStack &S,ElemType &x){
 if(S.top==-1)
        return false;
    x=S.data[S.top--];
        return true;
}

3.5 读栈顶元素操作

bool GetTop(SqStack &S,ElemType &x){
 if(S.top==-1)
        return false;
    x=S.data[S.top];
        return true;
}

4. 共享栈

两个栈共享同一片空间

#define MaxSize 10           //定义栈中元素的最大个数 
typedef struct{
 ElemType data[MaxSize];   //静态数组存放栈中的元素
    int top0;     //0号栈栈顶指针
    int top1;     //1号栈栈顶指针
}SqStack;         //结构体重命名
初始化栈:
void InitStack(ShStack &S){
 S.top0=-1;
 S.top1=MaxSize;
}

5. 链栈的定义

进栈 / 出栈都只能在栈顶一段进行

链头作为栈顶

typedef struct Linknode{
 ElemType data;           //数据域
    struct Linknode *next;   //指针域
}*LiStack                    //栈类型定义






审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 数据结构
    +关注

    关注

    3

    文章

    571

    浏览量

    40077

原文标题:详解数据结构中栈的定义和操作

文章出处:【微信号:OSC开源社区,微信公众号:OSC开源社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    一文详解Linux的各种

    (push) 和 弹出 (pop) 操作。根据的特点,很容易的想到可以利用数组,来实现这种数据结构。但是本文要讨论的并不是软件层面的,而是硬件层面的
    发表于 09-28 14:51 1295次阅读

    数据结构

    1.数据结构的概念 所谓数据结构是指由某一数据对象及该对象中所有数据成员之间的关系组成的集合。成员之间的关系有很多种,最常见的是前后件关系。 2.
    发表于 03-04 14:13

    大话数据结构pdf下载

    大话数据结构是一本很值得初学者看的编程书籍,用简单的语言然人深刻的理解数据结构,强烈程序员推荐下载收藏,下面是部分内容预览: 完整的pdf格式电子书下载: 《大话数据结构》.pdf
    发表于 07-04 00:33

    收藏 | 程序员面试,你必须知道的8大数据结构

    本文我们介绍了应对程序员面试过程,必须掌握的几大数据结构。几乎所有的问题都需要面试者对数据结构有深刻的理解。无论你是初入职场的新兵(刚从大学或者编程培训班毕业),还是拥有几十年经验的职场老鸟。有些
    发表于 09-30 09:35

    常见的数据结构

    的,那样对于数据的使用简直是个悲剧。针对此类数据数据结构提供了图存储结构,专门用于存储这类数据。二、
    发表于 05-10 07:58

    数据结构之链式介绍

    数据结构之链式链式链式定义链式操作的实现链
    发表于 12-17 08:11

    数据结构链表的基本操作

    嵌入式学习基础-数据结构链表的基本操作链表节点采用结构体的方式进行定义,下面是最基础的定义只有一个数据
    发表于 12-22 08:05

    java数据结构学习

    数据结构是对计算机内存数据的一种安排,数据结构包括 数组, 链表, , 二叉树, 哈希表等,算法则对对这些
    发表于 11-29 09:46 764次阅读

    什么是数据结构?为什么要学习数据结构数据结构的应用实例分析

    本文档的主要内容详细介绍的是什么是数据结构?为什么要学习数据结构数据结构的应用实例分析包括了:数据结构在串口通信当中的应用,数据结构在按键
    发表于 09-26 15:45 14次下载
    什么是<b class='flag-5'>数据结构</b>?为什么要学习<b class='flag-5'>数据结构</b>?<b class='flag-5'>数据结构</b>的应用实例分析

    什么是?数据结构如何实现

    今天放松一下,我们来看看数据结构,这节的知识点可以说是数据结构中最容易上手的知识点了,其实比起链表,其实链表也有和队列的模型,链表的
    发表于 04-29 18:25 0次下载
    什么是<b class='flag-5'>栈</b>?<b class='flag-5'>数据结构</b><b class='flag-5'>中</b><b class='flag-5'>栈</b>如何实现

    数据结构堆栈出序列问题解析

    这是工作遇到的小问题。 数据结构中有一种数据类型堆栈,该结构数据项有如下特点: 除了最前面
    的头像 发表于 10-19 15:46 3287次阅读
    <b class='flag-5'>数据结构</b><b class='flag-5'>中</b>堆栈出<b class='flag-5'>栈</b>序列问题解析

    如何解决数据结构设计最大频率问题?

    读完本文,可以去力扣解决如下题目: 895.最大频率(Hard)   我个人很喜欢设计特殊数据结构的问题,毕竟在工作中会经常用到基本数据结构,而设计类的问题就非常考验对基本数据结构
    的头像 发表于 03-02 11:02 1393次阅读

    SystemVerilog可以嵌套的数据结构

    SystemVerilog除了数组、队列和关联数组等数据结构,这些数据结构还可以嵌套。
    的头像 发表于 11-03 09:59 1548次阅读

    数据结构解决滑动窗口问题

    前文用 [单调解决三道算法问题]介绍了单调这种特殊数据结构,本文写一个类似的数据结构「单调队列」。 也许这种数据结构的名字你没听过,其
    的头像 发表于 04-19 10:50 624次阅读
    <b class='flag-5'>数据结构</b>解决滑动窗口问题

    Linux的进程、线程、内核以及中断

    (push) 和 弹出 (pop) 操作。根据的特点,很容易的想到可以利用数组,来实现这种数据结构。但是本文要讨论的并不是软件层面的,而是硬件层面的
    的头像 发表于 05-14 09:30 667次阅读
    Linux<b class='flag-5'>中</b>的进程<b class='flag-5'>栈</b>、线程<b class='flag-5'>栈</b>、内核<b class='flag-5'>栈</b>以及中断<b class='flag-5'>栈</b>