详解数据结构中栈的定义和操作
作者 | 华为云开发者联盟-高彬滔
原文链接:https://my.oschina.net/u/4526289/blog/8676861
摘要:本文为大家详解数据结构中栈的定义和操作。
1. 栈的定义
空栈:不含元素的空标配
栈顶:表尾端
栈底:表头端
进栈顺序: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 返回栈顶元素
3. 顺序栈
3.1 顺序栈的定义
#define MaxSize 10 //定义栈中元素的最大个数
typedef struct{
ElemType data[MaxSize]; //静态数组存放栈中的元素
int top; //栈顶指针
}SqStack; //结构体重命名
声明一个顺序栈后就会在内存中分配一整片连续的空间,其中内存大小为:MaxSize*sizeof (ELemType)
void testStack(){
SqStack S; //声明一个顺序栈
}
3.2 栈的初始化操作
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 //栈类型定义
END
🌟 活动推荐
2023 年 5 月 27-28 日,GOTC 2023 全球开源技术峰会将在上海张江科学会堂隆重举行。
为期 2 天的开源行业盛会,将以行业展览、主题发言、特别论坛、分论坛、快闪演讲的形式来诠释此次大会主题 ——“Open Source, Into the Future”。与会者将一起探讨元宇宙、3D 与游戏、eBPF、Web3.0、区块链等热门技术主题,以及 OSPO、汽车软件、AIGC、开源教育培训、云原生、信创等热门话题,探讨开源未来,助力开源发展。
长按识别下方二维码立即查看 GOTC 2023 详情/报名。
微信扫码关注该文公众号作者