详解数据结构中栈的定义和操作|天天快讯
时间:2023-04-20 21:50:41 来源:博客园
【资料图】
摘要:本文为大家详解数据结构中栈的定义和操作。
本文分享自华为云社区《数据结构:详细讲解栈的定义、栈的操作》,作者: 高彬滔 。
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 //栈类型定义
点击关注,第一时间了解华为云新鲜技术~
标签:
最新文章推荐
- 详解数据结构中栈的定义和操作|天天快讯
- 全球微资讯!全民关注痛风日丨痛风患者日常该如何饮食运动?专家讲解来了
- 头条:山东泗水两辆重型半挂牵引车发生碰撞,致7死10伤
- A股旅游股几乎全线下跌,“上市旅游企业今年一季报值得期待”
- 65岁老人染赌博恶习!绑架亲外孙开价勒索50万
- 【播资讯】潮评丨4.9%,干得漂亮!
- 全球微头条丨长盈通: 武汉长盈通光电技术股份有限公司利润分配方案公告
- 今日播报!IGN 2023年“游戏之夏”活动将于6月回归
- 世界信息:我省最大整县推进分布式光伏项目开始并网发电
- 郑州小学转学条件及流程要求|全球简讯
- 每日速读!支持民企发展公平是关键
- 如果一个男的,带一个女孩去喝酒,喝完就带回家了,结果发生了关系-环球关注
- 世界今日讯!引进一个 带来一批 辐射一片——晋中市以“政府+链主企业+产业园”招商模式赋能新兴产业集群发展
- 上海车展展台区别对待中外访客?MINI中国公开致歉
- 环球精选!辽宁法库农村人居环境细梳妆
- 【天天新要闻】南方先进制造业专场招聘会在广东工大举办
- 港元拆息全线向上|要闻
- 死亡岛2加速器推荐 死亡岛2免费好用加速器下载_环球观焦点
- 季后赛不装了!巴特勒连续两场首节砍至少13分 4年热火生涯首次
- 环境损害司法鉴定机构登记评审细则_关于环境损害司法鉴定机构登记评审细则介绍
- 【环球新要闻】空调外面的风扇不转不够冷吗_空调外面的风扇不转
- 湖北赤壁:强党建聚人心兴产业 驻村工作队为乡村振兴蓄势赋能
- 当前时讯:浙商证券:给予明月镜片增持评级
- 世界热消息:莱音珠宝铂金多少钱一克(2023年04月19日)参考价格
- 白果每天可以吃多少?
- 全球快看点丨科瑞技术董秘回复:公司股权激励计划参照证监会规则的相关要求实施,详情可关注公司披露的相关公告
- 上海车展| 中信科智联C-V2X车联网,赋能汽车智能网联化融合发展-当前简讯
- 美元加息是什么意思_加息的影响
- 血浆和血清的主要区别在于血浆中含有_血浆与血清的主要区别在于血浆中含有______ 天天最新
- 商薯19的种植技巧病虫防治高产方案 全球视点
X 关闭
资讯中心
2023-02-01
2022-08-29
2022-08-15
2022-05-20
X 关闭
热点资讯
-
1
1月11日午后两市机构大单抢筹40股(名单)
-
2
【天天速看料】王俊凯疑坐实性丑闻!网传将被封杀,正在走程序,涉顶流女星杨幂
-
3
六福内地铂金多少钱一克(2023年01月10日)-世界消息
-
4
在岸离岸人民币对美元汇率双双升破“6.9” 专家预计本月将延续波动回升态势 每日速看
-
5
2023年首单!超126倍认购 嘉实京东仓储基础设施REIT吸金近720亿元 环球新资讯
-
6
环球观热点:叮当钱包借款逾期1年还不起会上征信系统吗
-
7
光华股份:公司主营粉末涂料用聚酯树脂,没有POE胶膜相关产品 看热讯
-
8
WD-40(WDFC.US):2023年Q1财报实现营收1.249亿美元_全球观天下
-
9
微粒贷逾期一年还不起征信会怎么样
-
10
基金:开年五连阳怎么办
-
11
赣州轻微工伤如何计算
-
12
5个案例:难以描述的需求,PRD越抹越黑?
-
13
世界观点:粤港跨境巴士恢复运行:恢复通关,感觉日子更有盼头
-
14
猫的英文怎么说 猫的英文是什么
-
15
今日热门!数据海报丨2022年长沙高质量发展报告·宜居之城品质倍升
-
16
英方软件(688435):首发网上路演时间 2023年1月9日(T-1日,周一)9:00~12:00
-
17
2021年12月几号有雪?
-
18
快播:特斯拉上海被曝停产一周,股票暴跌,到底发生什么了?
-
19
[快讯]乐心医疗发布解除质押公告
-
20
家政创业成功的3大核心,你了解吗?|速看