1 Star 1 Fork 0

Mengs/数据结构c语言版第2版

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
2-2-1双栈.c 1.25 KB
一键复制 编辑 原始数据 按行查看 历史
Mengs 提交于 2021-02-09 11:44 . 栈习题
#include <stdio.h>
#include <stdlib.h>
typedef struct {
int top[2], bot[2]; // 栈顶和栈底指针
int* V; // 栈数组
int m; // 栈最大可容纳数
}DblStack;
// 栈初始化
int InitDblStack(DblStack* S,int m) {
S->m = m;
S->V = (int*)malloc(sizeof(int)*m);
S->bot[0] = -1;
S->top[0] = -1;
S->bot[1] = m;
S->top[1] = m;
return 1;
}
// 栈空
int DblStackEmpty(DblStack* S) {
return S->top[1] == S->m || S->top[0] == -1?1:0;
}
// 栈满:栈满只需判断总栈是否满
int DblStackFull(DblStack* S) {
return S->top[1]-S->top[0]==1? 1 : 0;
}
// 第i号栈,e为入栈元素
int Push(DblStack* S,int i,int e) {
if (i < 0 || i>1) return 0;
// 判断栈满
if (DblStackFull(S)) return 0;
// 入栈
if (i) S->top[i]--;
else S->top[i]++;
S->V[S->top[i]] = e;
return 1;
}
int Pop(DblStack *S, int i,int *e) {
if (i < 0 || i>1) return 0;
if (DblStackEmpty(S)) return 0;
*e = S->V[S->top[i]];
if (i) S->top[i]++;
else S->top[i]--;
return 1;
};
int main() {
DblStack* S;
S = (DblStack*)malloc(sizeof(DblStack));
InitDblStack(S,5);
if (DblStackEmpty(S)) printf("栈空\n");
Push(S, 0, 0);
Push(S, 0, 1);
Push(S, 0, 2);
Push(S, 0, 3);
Push(S, 0, 4);
int i = 0,e=-1;
if (DblStackFull(S)) printf("\n栈满\n");
for (; i < 6; i++) {
Pop(S, 1, &e);
printf("%3d", e);
}
return 0;
};
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C
1
https://gitee.com/meng_s/data_structure.git
[email protected]:meng_s/data_structure.git
meng_s
data_structure
数据结构c语言版第2版
master

搜索帮助