数据结构与算法基础-学习-11-线性表之链栈的初始化、判断非空、压栈、获取栈长度、弹栈、获取栈顶元素

news2025/1/23 11:16:41

一、个人理解

链栈相较于顺序栈不存在上溢(数据满)的情况,除非内存不足,但存储密度会低于顺序栈,因为会多存一个指针域,其他逻辑和顺序表一致。总结如下:

  1. 头指针指向栈顶。

  1. 链栈没有头节点直接就是首元节点。

  1. 基本不会出现上溢的情况。

  1. 头指针为空,表示链栈为空,没有元素。

  1. 插入删除操作都是在栈顶(首元节点)操作。

二、链栈图解

三、结构体定义

1、ElemType

(1)说明

数据域,存放自定义数据。

(2)源码

typedef struct ElemType
{
    char StudentNum[StudentNumLen];
    char StudentName[StudentNameLen];
    int  StudentScore;
}ElemType;

2、Stack

(1)说明

链栈的数据域和指针域。

(2)源码

typedef struct Stack
{
    ElemType      Data;
    struct Stack* NextPointer;
}Stack;

3、LinkStack

(1)说明

多加了一个StackLen是为了提升计算链栈长度的效率,因为链栈不能像顺序栈一样用栈顶指针减去栈底指针得到栈长度,而是需要遍历整个链栈得到栈长度,时间复杂度为O(n),所以多加了一个参数StackLen,使得时间复杂度变为O(1)。

(2)源码

typedef struct LinkStack
{
    Stack*       StackTop;
    StackLenType StackLen;
}LinkStack;

四、函数定义

1、InitLinkStack

(1)用途

初始化链栈,头节点置为NULL,表示栈为空,后续入栈时,再申请空间。

(2)源码

Status InitLinkStack(LinkStack* LS)
{
    JudgeAllNullPointer(LS);
    LS->StackTop = NULL;
    LS->StackLen = 0;
    Log("Init LinkStack  : OK\n",Info);
    return SuccessFlag;
}

(3)参数

参数名

说明

LS

需要初始化的LinkStack*类型链栈。

2、JudgeLinkStackIsEmpty

(1)用途

判断链栈是否为空,如果头指针为空,则链栈为空,反之非空。

(2)源码

Status JudgeLinkStackIsEmpty(LinkStack* LS)
{
    JudgeAllNullPointer(LS);
    if(LS->StackTop == NULL)
    {
        Log("Judge LinkStack: Empty\n",Debug);
        return SuccessFlag;
    }
    Log("Judge LinkStack: Not Empty\n",Debug);
    return FailFlag;
}

(3)参数

参数名

说明

LS

需要判断是否为空的LinkStack*类型链栈。

3、GetLinkStackLen

(1)用途

获取链栈的长度。

(2)源码

StackLenType GetLinkStackLen(LinkStack* LS)
{
    JudgeAllNullPointer(LS);
    return LS->StackLen;
}

(3)参数

参数名

说明

LS

需要获取长度的LinkStack*类型链栈。

4、PushLinkStack

(1)用途

压栈,将数据放入链栈中。

(2)源码

Status PushLinkStack(LinkStack* LS, ElemType E)
{
    JudgeAllNullPointer(LS);

    Stack* NewStack       = (Stack*)MyMalloc(sizeof(Stack));
    NewStack->Data        = E;
    NewStack->NextPointer = LS->StackTop;
    LS->StackTop          = NewStack;

    LS->StackLen++;

    Log("Push LinkStack  : OK\n",Info);
    return SuccessFlag;
}

(3)参数

参数名

说明

LS

需要压栈的LinkStack*类型链栈。

E

需要压栈的ElemType类型数据。

5、GetLinkStackTop

(1)用途

获取栈顶元素数据域,返回一个ElemType类型数据。

(2)源码

ElemType GetLinkStackTop(LinkStack* LS)
{
    JudgeAllNullPointer(LS);
    return LS->StackTop->Data;
}

(3)参数

参数名

说明

LS

需要获取栈顶元素数据域的LinkStack*类型链栈。

6、PopLinkStack

(1)用途

弹栈,将栈顶的数据删除。

(2)源码

Status PopLinkStack(LinkStack* LS, ElemType* E)
{
    JudgeAllNullPointer(LS);
    JudgeAllNullPointer(E);
    if(JudgeLinkStackIsEmpty(LS) == SuccessFlag)
    {
        Log("LinkStack is Empty, Data cannot be poped\n",Warning);
        return FailFlag;
    }

    LS->StackLen--;
    *E = LS->StackTop->Data;
    Stack* Tmp = LS->StackTop;
    LS->StackTop = LS->StackTop->NextPointer;

    free(Tmp);
    Tmp = NULL;
    Log("Pop LinkStack   : OK\n",Info);
    return SuccessFlag;
}

(3)参数

参数名

说明

LS

需要弹栈的LinkStack*类型链栈。

E

需要弹栈的ElemType*类型数据,是一个输出参数。

五、虚机测试

[gbase@czg2 LinearTable_LinkStack]$ make
gcc -Wall -O3 ../Log/Log.c LinkStack.c main.c -o TestLinkStack -I ../Log/

[gbase@czg2 LinearTable_LinkStack]$ ./TestLinkStack 
2023-2--Info--Init LinkStack  : OK
2023-2--Debug--Judge LinkStack: Empty
2023-2--Info--Push LinkStack  : OK
2023-2--Info--Push LinkStack  : OK
2023-2--Info--Push LinkStack  : OK
2023-2--Info--Push LinkStack  : OK
2023-2--Info--Push LinkStack  : OK
2023-2--Info--Push LinkStack  : OK
2023-2--Info--Push LinkStack  : OK
2023-2--Info--Push LinkStack  : OK
2023-2--Debug--Judge LinkStack: Not Empty
2023-2--Debug--ElemType Data  :
StudentNum     : X666
StudentName    : Sun
StudentScore   : 107
2023-2--Debug--LinkStack Data :
StudentNum     : X666
StudentName    : Sun
StudentScore   : 107
+++++++++++++++
StudentNum     : X666
StudentName    : Sun
StudentScore   : 106
+++++++++++++++
StudentNum     : X666
StudentName    : Sun
StudentScore   : 105
+++++++++++++++
StudentNum     : X666
StudentName    : Sun
StudentScore   : 104
+++++++++++++++
StudentNum     : X666
StudentName    : Sun
StudentScore   : 103
+++++++++++++++
StudentNum     : X666
StudentName    : Sun
StudentScore   : 102
+++++++++++++++
StudentNum     : X666
StudentName    : Sun
StudentScore   : 101
+++++++++++++++
StudentNum     : X666
StudentName    : Sun
StudentScore   : 100
+++++++++++++++
LinkStackLen   : 8
2023-2--Debug--Judge LinkStack: Not Empty
2023-2--Info--Pop LinkStack   : OK
2023-2--Debug--ElemType Data  :
StudentNum     : X666
StudentName    : Sun
StudentScore   : 107
2023-2--Debug--Judge LinkStack: Not Empty
2023-2--Info--Pop LinkStack   : OK
2023-2--Debug--ElemType Data  :
StudentNum     : X666
StudentName    : Sun
StudentScore   : 106
2023-2--Debug--Judge LinkStack: Not Empty
2023-2--Info--Pop LinkStack   : OK
2023-2--Debug--ElemType Data  :
StudentNum     : X666
StudentName    : Sun
StudentScore   : 105
2023-2--Debug--Judge LinkStack: Not Empty
2023-2--Info--Pop LinkStack   : OK
2023-2--Debug--ElemType Data  :
StudentNum     : X666
StudentName    : Sun
StudentScore   : 104
2023-2--Debug--Judge LinkStack: Not Empty
2023-2--Info--Pop LinkStack   : OK
2023-2--Debug--ElemType Data  :
StudentNum     : X666
StudentName    : Sun
StudentScore   : 103
2023-2--Debug--Judge LinkStack: Not Empty
2023-2--Info--Pop LinkStack   : OK
2023-2--Debug--ElemType Data  :
StudentNum     : X666
StudentName    : Sun
StudentScore   : 102
2023-2--Debug--Judge LinkStack: Not Empty
2023-2--Info--Pop LinkStack   : OK
2023-2--Debug--ElemType Data  :
StudentNum     : X666
StudentName    : Sun
StudentScore   : 101
2023-2--Debug--Judge LinkStack: Not Empty
2023-2--Info--Pop LinkStack   : OK
2023-2--Debug--ElemType Data  :
StudentNum     : X666
StudentName    : Sun
StudentScore   : 100
2023-2--Debug--LinkStack Data :
LinkStackLen   : 0

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/346632.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

智慧校园应用系统建设方案

系统简介 建设“智慧校园”的核心是创新新形势下高校发展理念、推进高校建设转型、变革高校管理行为方式;建设“智慧校园”的目的是推进信息化进入高校、服务管理、惠及师生;建设“智慧”的目标是实现 “信息采集、数据整合、信息促管、信息育人、信息联…

linux之echo使用技巧

参考文章:linux基本功系列-echo命令实战一、echo 命令是什么?作用: echo命令能将指定文本显示在Linux命令行上,或者通过重定向符写入到指定的文件中。语 法:echo [-ne][字符串] / echo [–help][–version]补充说明&am…

VMware安装CentOS7

个人简介:云计算网络运维专业人员,了解运维知识,掌握TCP/IP协议,每天分享网络运维知识与技能。个人爱好: 编程,打篮球,计算机知识个人名言:海不辞水,故能成其大;山不辞石…

Java+Python+HanLP自然语言处理包实现解析文本分词

目录 需要安装 Python部分 Java部分 需要安装 HanLP官网Api教程 https://bbs.hanlp.com/t/hanlp2-1-restful-api/53 首先需要电脑安装Python环境并配置环境变量(网上搜就可以一大堆教程),建议Python版本3 然后根据HanLP官网教程安装hanl…

「JVM 原理使用」 实际开发中的应用

Class 文件格式、执行引擎主要以 Class 文件描述了存储格式、类何时加载、如何连接、VM 如何执行字节码指令,这些动作基本都是 JVM 直接控制,用户代码无法干预和改变; 用户可以干预的只有字节码生成、类加载器两部分,而这两部分的…

Android 面试 基础知识汇总

Android常用的设计模式HTTP和HTTPS的区别TCP/UDP的区别

PendingIntent兼容安卓12 的一个问题

这是我第一次遇到这个问题,反正我也是第一次做完整的安卓app,很多个第一次。我之前做的那个老旧手机做桌面摆件的app,因为原来的“无干预”版本无法使用,所以又用回了“和风版”,但这个版本很久没用了,有些…

实用机器学习-学习笔记

文章目录9.1模型调参9.1.1思考与总结9.1.2 基线baseline9.1.3SGD ADAM9.1.4 训练代价9.1.5 AUTOML9.1.6 要多次调参管理9.1.7复现实验的困难9.1模型调参 9.1.1思考与总结 1了解了baseline和调参基本原则 2了解了adams和sgd的优劣 3了解了训练树和神经网络的基本代价 4了解了a…

【蓝桥杯集训2】差分专题(3 / 4)

目录 差分模板 1、一维差分 2、二维差分 3729. 改变数组元素 - 差分 区间修改 100. 增减序列 - 差分模板 1、一维差分 活动 - AcWing 给a数组 [l,r] 区间的每个数c,只需要给其差分数组b做如下操作即可 b[l]c; b[r1]-c; 差分数组 a[]是b[]的前缀和数组 如果…

倒计时100天 | DBF深圳国际户外运动博览会5月一起狂飙初夏

狂飙初夏的大型户外运动嘉年华即将登场!2023年5月26日至28日,第四届DBF深圳国际户外运动博览会(简称DBF深圳户外展)将于深圳国际会展中心(宝安)举办。本届展会展览面积超过7万平方米,预计将吸引…

保姆级Vue3+Vite项目实战黑白模式切换

写在前面注:本文首发掘金签约专栏,此为文章同步!本文为 Vue3Vite 项目实战系列教程文章第四篇,系列文章建议从头观看效果更佳,大家可关注专栏防走失!点个赞再看有助于全文完整阅读!此系列文章主…

C/C++【内存管理】

✨个人主页: Yohifo 🎉所属专栏: C修行之路 🎊每篇一句: 图片来源 Love is a choice. It is a conscious commitment. It is something you choose to make work every day with a person who has chosen the same thi…

商城系统必备营销工具(五)——积分商城

做商城,流量必不可少,日活跃度也很重要。现在各大APP、网站、小程序和微商城,基本都在为了巩固流量做积分商城,虽然已经随处可见,但很多企业商家却并没有将积分商城运作起来,积分商城也没有人浏览兑换商品。…

跟ChatGPT,聊聊ChatGPT

不仅“上知天文、下知地理”,似乎还能对答如流、出口成诗,甚至还能写剧本、编音乐、写代码——最近,一款名叫ChatGPT的人工智能聊天机器人火爆全球。由此,一系列关于新一代技术变革、人工智能替代人力、巨头企业扎堆入局AI的讨论在…

Multi Paxos

basic paxos 是用于确定且只能确定一个值,“只确定一个值有什么用?这可解决不了我面临的问题,例如每个用户都要多次保存数据.” 你心中可能有这样的疑问。 原simple paxos论文里有提到一连串个instance of paxos [4] 但没有提出 multi paxos的概念&…

ChatGPT国内镜像站试用,聊天、Python代码生成。

ChatGPT国内镜像站试用,聊天、Python代码生成。 (本文获得CSDN质量评分【91】)【学习的细节是欢悦的历程】Python 官网:https://www.python.org/ Free:大咖免费“圣经”教程《 python 完全自学教程》,不仅仅是基础那么简单…… …

前端开发:关于diff算法详解

前言 前端开发中,关于JS原生的内容和前端算法相关的内容一直都是前端工作中的核心,不管是在实际的前端业务开发还是前端求职面试,都是非常重要且必备的内容。那么本篇博文来分享一个关于前端开发中必备内容:diff算法,d…

ChatGPT背后的技术可以给数据治理带来哪些神奇的效果?_光点科技

最近,由美国人工智能研究室OpenAI开发的全新“聊天机器人”ChatGPT火了。作为一款人工智能语言模型,它不仅能和人展开互动,还可以写文章、制定方案、创作诗歌,甚至编写代码、检查漏洞样样精通,上线仅两个月全球活跃用户…

Python雪花代码

前言 用python画个雪花玩玩,源码在文末公众号哈。 雪花类 class Snow(): #雪花类 def __init__(self): self.r 6 #雪花的半径 self.x ra.randint(-1000,1000) #雪花的横坐标 self.y ra.randint(-500,5…

剑指 Offer 10- I. 斐波那契数列[c语言]

目录题目思路代码结果该文章只是用于记录考研复试刷题题目 力扣斐波那契数列 写一个函数,输入 n ,求斐波那契(Fibonacci)数列的第 n 项(即 F(N))。斐波那契数列的定义如下: F(0) 0, F(1) 1 …