您的位置:首页 > 理论基础 > 数据结构算法

数据结构 链栈的基本操作

2013-12-10 19:20 134 查看
#include <stdio.h>

#define OK         1
#define ERROR      0
#define OVERFLOW   -2

typedef int SElemType;

typedef struct StackNode
{
SElemType data;
struct StackNode *next;
}StackNode, *LinkStackPtr;

typedef struct LinkStack
{
LinkStackPtr top;
int count;
}LinkStack;

int Push(LinkStack &S, SElemType e)
{
LinkStackPtr s = (LinkStackPtr) malloc(sizeof(StackNode));
s->data = e;
s->next = S.top;
S.top = s;
S.count++;
return OK;
}

int Pop(LinkStack &S, SElemType &e)
{
LinkStackPtr p;
if (stackEmpty(S))
return ERROR;
e = S.top ->data ;
p = S.top ;
S.top = S.top ->next ;
free(p);
S.count --;
return OK;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: