Redian新闻
>
详解数据结构中栈的定义和操作

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

公众号新闻

来源 | OSCHINA 社区

作者 | 华为云开发者联盟-高彬滔

原文链接:https://my.oschina.net/u/4526289/blog/8676861


摘要:本文为大家详解数据结构中栈的定义和操作。
本文分享自华为云社区《数据结构:详细讲解栈的定义、栈的操作》,作者:高彬滔 。

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. 判断栈是否为空

  2. 栈顶指针 + 1

  3. 新元素入栈

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 //栈类型定义


END



谷歌开发全新搜索引擎Magi,由人工智能技术驱动


🌟 活动推荐


2023 年 5 月 27-28 日,GOTC 2023 全球开源技术峰会将在上海张江科学会堂隆重举行。

为期 2 天的开源行业盛会,将以行业展览、主题发言、特别论坛、分论坛、快闪演讲的形式来诠释此次大会主题 ——“Open Source, Into the Future”。与会者将一起探讨元宇宙、3D 与游戏、eBPF、Web3.0、区块链等热门技术主题,以及 OSPO、汽车软件、AIGC、开源教育培训、云原生、信创等热门话题,探讨开源未来,助力开源发展。

长按识别下方二维码立即查看 GOTC 2023 详情/报名。


微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
结合了英国极简主义和日式禅意的老屋改造!【居住榜样】“教父”麦卡锡和操控他的共和党“五大家族”总统提名:前MasterCard CEO Ajay Banga,head World Bank解数咨询:水族世界行业调研(100页)机构改革对金融体系动大手术,剑指美式自由主义和金融腐败!西班牙占屋运动:贫富分化、反资本主义和制度困境聊聊 微服务 架构中的用户认证方案GPT-3解数学题准确率升至92.5%!微软提出MathPrompter,无需微调即可打造「理科」语言模型一条SQL如何被MySQL架构中的各个组件操作执行的?奥克维尔精选房源:顶级学校旁奢华的定制住宅,好想在自家雪地上撒点野儿~缤趣小方母婴连锁联合创始人金勇:以“货”和“场”重构中小母婴店突围之路[日签]​ “美丽”的定义解数:盘点海外美妆2022行业及品牌表现,展望2023解数:膳食营养-益生菌行业调研报告(142页)YouTube上的脱口秀如何破解数字疗法落地难点,海南推动应用场景创新落地微服务架构中多级缓存设计慢性心力衰竭恶化的定义、管理和预防丨2023 ESC-HFA临床共识声明解数咨询:猫砂行业及优秀品牌分析(130页)让大模型像学生一样解数学题,正确率提升14%,微软的MathPrompter了解一下微服务架构中的数据一致性:解决方案与实践Java中堆和栈的区别Careers at the FTC(Federal Trade Commission):【初次】发现她学中文,是要出轨中国男人。解数:面膜行业调研报告(130页)推荐 |《数据资产价值实现研究报告》发布:6万字详解数据价值卡萨帝的“自定义与被定义”10分钟带你了解数据分析的三大门类!情感主播的假正义和“爹妈们”的真感情工作伦理的形成《工作 消费主义和新穷人》解数咨询:婴儿手推车学步车行业调研报告华女嫁大30岁老头,用尽浑身解数抱走1000万美元...LinkedIn大佬揭秘大公司裁员逻辑和操作机制,如何决定裁掉谁?谈观点说方法:增加什么活动能帮助孩子理解数概念呢?形势似乎在往最坏的方向发展
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。