顺序栈 跟顺序表类似,比顺序表要简单一些,顺序栈是被限制的顺序表 只允许栈顶取出和插入 要简单很多

#define StackInintSize 100 //初始栈的大小
#define StackCrement 10     // 后面进栈的时候可能栈大小不够  这是预设的增量

typedef struct SqStack{  //栈结构体 
    int *base;
    int top;
    int stacksize;
}S;

void InitSqStack(SqStack &S){
    S.base=(int *)malloc(StackInintSize*sizeof(int));
    if(!s.base){
        return;
    }
    S.top=0;
    S.stacksize=StackInintSize;
}

int StackEmpty(SqStack S){
    if(S.top == 0){
        return 1;
    }
    return 0;
}

int StackLength(SqStack S){
    return S.top;
}

void Push(SqStack &S, int e){
    if(S.top == S.stacksize){
        S.base=(int *)malloc((StackInintSize+StackCrement)*sizeof(int));
        if (!S.base){
            return;
        }
        S.stacksize += StackCrement;
    }
    S.top=e;
    S.top++;
}

void GetTop(SqStack S,int &e){
    if(S.top == 0){
        return;
    }
    e=S.top;
    S.top--;
    S.base--;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值