详解数据结构中栈的定义和操作
摘要:本文为大家详解数据结构中栈的定义和操作。
本文分享自华为云社区《数据结构:详细讲解栈的定义、栈的操作》,作者: 高彬滔 。
1.栈的定义
栈(stack):是只允许在一端进行插入或者删除操作的线性表(即后进先出,大概可以理解为吃饱了吐出来)
- 空栈:不含元素的空标配
- 栈顶:表尾端
- 栈底:表头端
- 进栈顺序: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.顺序栈
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 //栈类型定义

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
云原生2.0网关API标准发展趋势
摘要:Gateway API希望取代Ingress API。 本文分享自华为云社区《云原生2.0网关API标准发展趋势》,作者:华为云云原生团队 。 云原生网关API标准背景及发展现状 Gateway API是一个开源的API标准,源自Kubernetes SIG-NETWORK兴趣组。从出身角度讲,可谓根正苗红,自从开源以来备受关注,被寄予厚望。Gateway API旨在通过声明式、可扩展性和面向角色的接口来发展Kubernetes服务网络,并且希望成为供应商的网关API标准并获得广泛行业支持。简而言之,Gateway API希望取代Ingress API。 Gateway API 项目自2019年开源,但是经历了缓慢的发展,直到2022年7月才发布Beta版本,同时发起了GAMMA(Gateway API for Mesh Management and Administration)。笔者认为这里主要有两方面的原因: - Ingress存在已久,并且是几乎所有的Ingress Controller的默认实现,Kubernetes的用户早已习惯Ingress,尽管Ingress在易用...
- 下一篇
带你掌握数仓的作业级监控TopSQL
摘要:目前TopSQL功能被用户广泛使用,是性能定位、劣化分析、审计回溯等重要的基石,为用户提供覆盖内存、耗时、IO、网络、空间等多方面的监控能力。 本文分享自华为云社区《GaussDB(DWS)监控工具指南(一)作业级监控TopSQL》,作者:幕后小黑爪 。 1、引言: 监控系统是智能化管理和自动化运维的基石,可以为资源规划,故障排查,性能优化提供至关重要的数据支持。GaussDB(DWS)作为企业级数仓,为用户提供了一整套覆盖实例级、用户级、作业级的资源监控能力,其中,作业级监控(下文统称为TopSQL)主要是对运行作业的监控,包括了实时运行作业的相关信息,历史运行作业的相关信息等。它收集的数据来源于数据库内部,为用户提供了实时监控数据库的能力。 目前TopSQL功能被用户广泛使用,是性能定位、劣化分析、审计回溯等重要的基石,为用户提供覆盖内存、耗时、IO、网络、空间等多方面的监控能力。 本文以数仓813版本作为基线,对TopSQL进行介绍。 2、TopSQL功能介绍 对于用户而言,数据库是个黑盒,输入SQL语句,输出预期结果。在此过程中,用户关心两点: 输出结果是否符合预期; 语...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS8安装Docker,最新的服务器搭配容器使用
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- Windows10,CentOS7,CentOS8安装Nodejs环境
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS8编译安装MySQL8.0.19