C语言实现数据结构——栈的顺序存储结构

源码

/**
  * 创建时间 : 2022/5/18 15:42
  * 作   者 : Marson
  * 内   容 : 栈的顺序存储结构
  */

#include<stdio.h>
#include<stdlib.h>

#define bool char
#define false 0
#define true 1

#define MaxSize 100

typedef int ElemType;

typedef struct {
    ElemType *base;
    ElemType *top;
    int stacksize;
}SqStack;


/**
 * 栈的初始化
 */
bool InitStack(SqStack *S) {
    S->base = (ElemType*) malloc(MaxSize * sizeof(ElemType));
    if(!S->base) {
        printf("创建空栈失败!\n");
        exit(0);
    }
    S->top = S->base;
    S->stacksize = MaxSize;
    return true;
}


/**
 * 判断栈是否为空
 */
bool Empty(SqStack *S) {
    if (S->top == S->base) return true;
    else return false;
}


/**
 * 入栈
 */
bool Push(SqStack *S, ElemType e) {
    if (S->top - S->base == MaxSize) {
        printf("栈满!不能再入栈!\n");
        return false;
    }
    *S->top = e;          // 先赋值top再加一
    S->top++;
    return true;
}


/**
 * 出栈
 */
bool Pop(SqStack *S, ElemType *e) {
    if (Empty(S)) {
        return false;
    };
    S->top--;
    *e = *S->top;          // 先减一再取值
    return true;
}


/**
 * 取栈顶元素
 */
ElemType GetTop(SqStack S) {
    if (S.top != S.base)
    return *(S.top-1);
}


/**
 * 获取栈的长度
 */
int GetLength(SqStack *S) {
    if (S->base == NULL) {
        printf("栈为空!\n");
        return 0;
    }
    return S->top - S->base;
}


/**
 * 输出栈
 */
bool PrintStack(SqStack *S) {
    if (Empty(S)) return false;
    ElemType *p;
    p = S->top;
    while (p != S->base) {
        p--;                        // 顺序不能改
        printf("%d\n", *p);
    }
    return true;
}


int main() {
    SqStack *S;
    SqStack s;
    S = &s;

    int chooseNumber;
    int elem;
    bool ans;
    int length;

    InitStack(S);
    printf("容量为100的空栈建立成功!\n");

    while (1) {
        printf("******************************\n");
        printf("请操作:\n");
        printf("1(Push):入栈\n");
        printf("2(Pop):出栈\n");
        printf("3(Get):取栈顶元素\n");
        printf("4(Empty):判断是否为空\n");
        printf("5(Length):获取栈的长度\n");
        printf("6.(Print):输出栈\n");
        printf("0(exit):退出程序\n");
        printf("******************************\n");

        scanf("%d", &chooseNumber);
        switch (chooseNumber) {
            case 1:         // 入栈
                printf("请输入入栈元素:\n");
                scanf("%d", &elem);
                Push(S, elem);
                printf("入栈成功!\n");
                break;
            case 2:         // 出栈
                ans = Pop(S, &elem);
                if (ans) printf("出栈成功!出栈元素为%d\n",elem);
                else printf("栈空!不能再出栈!\n");
                break;
            case 3:
                if (Empty(S)) {
                    printf("栈为空!不能再取栈首元素!\n");
                    break;
                }
                elem = GetTop(*S);
                printf("栈首元素为:%d\n", elem);
                break;
            case 4:
                ans = Empty(S);
                if (ans) printf("栈为空!\n");
                else printf("栈非空!\n");
                break;
            case 5:
                length = GetLength(S);
                printf("当前栈的长度为%d\n", length);
                break;
            case 6:
                ans = PrintStack(S);
                if (ans) printf("当前栈元素如下:\n");
                else printf("栈为空!无输出!\n");
                break;
            case 0:
                exit(0);
                break;
            default:
                printf("输入错误,请重新输入:\n");
                break;
        }
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值