栈的创建、入栈、出栈操作(顺序结构)
各位大佬好,我是小白莲,今天小白莲给大家介绍的是栈的基本操作之创建、入栈、出栈操作。
首先说明一下,我用的是动态‘数组’,有些书本可能是直接调用数组,栈的最大容量就用个MAXSIZE来限定,动态数组的存储空间是可以灵活改变的,所以我采用的是动态‘数组’ 参考教材:《数据结构 C语言版》清华大学出版社 严蔚敏、吴伟民著
当然,如果觉得小白莲写得还不错,记得一定!一定!要点个赞再走哦!最好关注一下也是可以的,你们的对我的点赞和关注就是对我最大的支持,我真的很需要,谢谢!说的就是你,光收藏却不点赞,哼~~
1.定义栈的结构
#include<stdio.h>
#include<stdlib.h>
#define OK 1
#define ERROR 0
#define OVERFLOW -2
#define STACK_INIT_SIZE 100
#define STACKINCREMENT 10
typedef int SElemType
;
typedef int Status
;
typedef struct {
SElemType
* base
;
SElemType
* top
;
int stacksize
;
}SqStack
;
2.栈的初始化
Status
InitStack(SqStack
&S
) {
S
.base
= (SElemType
*)malloc(STACK_INIT_SIZE
* sizeof(SElemType
*));
if (!S
.base
) exit(OVERFLOW
);
S
.top
= S
.base
;
S
.stacksize
= STACK_INIT_SIZE
;
return OK
;
}
3.入栈操作
Status
Push(SqStack
& S
, SElemType e
) {
if (S
.top
- S
.base
>= S
.stacksize
) {
S
.base
= (SElemType
*)realloc(S
.base
,(S
.stacksize
+ STACKINCREMENT
) * sizeof(SElemType
));
if (!S
.base
) exit(OVERFLOW
);
S
.top
= S
.base
;
S
.stacksize
+= STACKINCREMENT
;
}
*S
.top
= e
;
S
.top
++;
return OK
;
}
4.出栈操作
注意:这里的出栈逻辑上把相应的元素‘删除’了(因为top指针往下移了一位),但存储空间还是有的,这个被‘删除’元素的存储空间在进栈时还可以被利用的,所以不用释放(当然也不能释放)
Status
Pop(SqStack
& S
,SElemType
&e
) {
if (S
.top
== S
.base
) return ERROR
;
--S
.top
;
e
= *S
.top
;
return OK
;
}
5.对初始化栈、入栈、出栈的测试
int main() {
SqStack stack
;
if (InitStack(stack
)) {
for (int i
= 1; i
<= 10; i
++)
{
if (Push(stack
, i
)) continue;
else ("入栈操作失败!\n");
}
SElemType e
;
for (int i
= 1; i
<= 10; i
++)
{
if (Pop(stack
, e
))
printf("%d ", e
);
else printf("出栈操作失败!\n");
}
}
else
{
printf("栈初始化失败!\n");
}
return 0;
}
5.1对初始化栈、入栈、出栈的测试结果
可以看到后进的元素先出来了(栈的‘后进先出’)
end
给人点赞,手留余香
预知后续操作如何,请看下集
@author 白莲居仙 QQ:1131977233