栈链

#include <iostream>
using namespace std;
 
// 函数结果状态代码
#define TRUE    1
#define FALSE   0
#define OK      1
#define ERROR   0
#define INFEASIBLE -1
#define OVERFLOW   -2
#define MAXSIZE    100
 
// Status 是函数的类型 其值是函数结果状态代码
typedef int Status;
typedef int SElemType;
 
typedef struct StackNode{
 
    SElemType data;
    struct StackNode *next;
}StackNode, *LinkStack;
 
// 链栈的初始化
Status InitStack(LinkStack &S){
 
    S = NULL;
    return OK;
}
 
// 判断链栈是否为空
Status StackEmpty(LinkStack S){
 
    if(S == NULL) return TRUE;
    else return FALSE;
}
 
// 链栈的入栈
Status Push(LinkStack &S, SElemType e){
 
    StackNode *p = NULL;
    p = new StackNode;      // 生成新节点p
    p->data = e;            // 讲新节点数据域置为e
    p->next = S;            // 讲新节点插入栈顶
    S = p;                  // 修改栈顶指针
    return OK;
}
 
// 链表的出栈
Status Pop(LinkStack &S, SElemType &e){
 
    if (S == nullptr) return ERROR;
    StackNode *p = nullptr;
    e = S->data;
    p = S;
    S = S->next;
    delete p;
    return OK;
}
 
// 取栈顶元素
SElemType GetTop(LinkStack S){
    if (S!= nullptr){
        return S->data;
    }
}
 
// 销毁栈
Status DestroyStack(LinkStack &S){
 
    StackNode *p = nullptr;
    while (S){
        p = S;
        S = S->next;
        delete p;
    }
    return OK;
}
 
// 栈置空操作
Status ClearStack(LinkStack &S
    StackNode *p, *q;
    p = S;
    while (p){
        q = p->next;
        delete p;
        p = q;
    }
    S = nullptr;
    return OK;
}
 
// 求栈的长度
int StackLength(LinkStack S){
 
    int length = 0;
    while (S){
        length++;
        S = S->next;
    }
    return length;
}
 
int main() {
 
    LinkStack S;
    SElemType e;
    InitStack(S);
    Push(S, 11);
    Push(S, 22);
    Push(S, 33);
    int length = StackLength(S);
    cout << "链栈长度: " << length << endl;
    Status ret = StackEmpty(S);
    if (ret == TRUE) cout << "空栈" << endl;
    else cout << "非空" << endl;
    SElemType temp = GetTop(S);
    cout << "栈顶元素: " << temp << endl;
    Pop(S, e);
    cout << "弹出的栈顶元素: " << e << endl;
 
    ClearStack(S);
    ret = StackEmpty(S);
    if (ret == TRUE) cout << "空栈" << endl;
    else cout << "非空" << endl;
 
    DestroyStack(S);
    return 0;
}
 
 
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值