#include <stdio.h>
#define MaxSize 10
typedef struct {
int data[MaxSize];
int top;
} SqStack;
void InitStack(SqStack *s) {
s->top = -1;
}
int Push(SqStack *s, int e) {
if (s->top == MaxSize-1) return -1;
s->data[++s->top] = e;
return 1;
}
int Pop(SqStack *s, int *e) {
if (s->top == -1) return -1;
*e = s->data[s->top--];
return 1;
}
int GetTop(SqStack s, int *e) {
if (s.top == -1) return -1;
*e = s.data[s.top];
return 1;
}
void StackPrintf(SqStack s) {
for (int i = s.top; i > -1; i--) {
printf("%i\n", s.data[i]);
}
}
int main() {
SqStack s;
InitStack(&s);
Push(&s, 23);
Push(&s, 3);
Push(&s, 45);
Push(&s, 78);
StackPrintf(s);
int e = -1;
Pop(&s, &e);
Pop(&s, &e);
GetTop(s, &e);
printf("%i\n", e);
return 0;
}
顺序栈
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- C#数据结构:顺序栈的两栈共享(双端栈) 栈的应用非常广泛,经常会出现在一个程序中需要同时使用多个栈的情况。若使用...
- //顺序栈入栈,取栈顶元素,出栈 #include #include #include #define MAX...
- //顺序栈初始化,判栈空,进栈,读栈顶元素,出栈 include <stdio.h> include <stdli...