链栈

来源:互联网 发布:恐惧未来知乎 编辑:程序博客网 时间:2024/06/02 13:55
// bo3-5.cpp 链栈(存储结构由c2-2.h定义)的基本操作(4个)// 部分基本操作是由bo2-8.cpp中的函数改名得来// 另一部分基本操作是由调用bo2-8.cpp中的函数(取特例)得来typedef SElemType ElemType; // 栈结点类型和链表结点类型一致#include"c2-2.h" // 单链表存储结构typedef LinkList LinkStack; // LinkStack是指向栈结点的指针类型#define InitStack InitList // InitStack()与InitList()作用相同,下同#define DestroyStack DestroyList#define ClearStack ClearList#define StackEmpty ListEmpty#define StackLength ListLength#include"bo2-8.cpp" // 无头结点单链表的基本操作Status GetTop(LinkStack S,SElemType &e){ // 若栈不空,则用e返回S的栈顶元素,并返回OK;否则返回ERRORreturn GetElem(S,1,e);}Status Push(LinkStack &S,SElemType e){ // 插入元素e为新的栈顶元素return ListInsert(S,1,e);}Status Pop(LinkStack &S,SElemType &e){ // 若栈不空,则删除S的栈顶元素,用e返回其值,并返回OK;否则返回ERRORreturn ListDelete(S,1,e);}void StackTraverse(LinkStack S,void(*visit)(SElemType)){ // 从栈底到栈顶依次对栈中每个元素调用函数visit()LinkStack temp,p=S; // p指向栈顶元素InitStack(temp); // 初始化临时栈tempwhile(p){Push(temp,p->data); // 由S栈顶到栈底,依次将栈元素入栈到temp栈p=p->next;}ListTraverse(temp,visit); // 遍历temp线性表}
// main3-5.cpp 检验bo3-5.cpp的主程序#include"c1.h"typedef int SElemType; // 定义栈元素的类型#include"bo3-5.cpp"void print(SElemType c){printf("%d ",c);}void main(){int j;LinkStack s;SElemType e;InitStack(s); // 初始化栈sfor(j=1;j<=5;j++) // 将2,4,6,8,10入栈Push(s,2*j);printf("栈中的元素从栈底到栈顶依次为");StackTraverse(s,print);Pop(s,e);printf("弹出的栈顶元素为%d\n",e);printf("栈空否: %d(1:空0:否)\n",StackEmpty(s));GetTop(s,e);printf("当前栈顶元素为%d,栈的长度为%d\n",e,StackLength(s));ClearStack(s);printf("清空栈后,栈空否: %d(1:空0:否),栈的长度为%d\n",StackEmpty(s),StackLength(s));DestroyStack(s);}

代码运行结果:

/*栈中的元素从栈底到栈顶依次为2 4 6 8 10弹出的栈顶元素为10栈空否: 0(1:空0:否)当前栈顶元素为8,栈的长度为4清空栈后,栈空否: 1(1:空0:否),栈的长度为0ress any key to continue*/


0 0
原创粉丝点击