栈系列一:顺序栈和链式栈C++实现

1.栈的特点

先进后出

2.栈的种类

顺序栈(数组实现)和链式栈(链表实现),双栈没有特别了解

3.栈的类定义
const int maxSize=50;
enum bool{false,true};
template<class T>
class Stack{
public:
    Stack(){};
    virtual void Push(const T& x)=0;
    virtual bool Pop(T& x)=0;
    virtual bool getTop(T& x)=0;//使用& x是将函数中的x的变化带回。
    virtual bool IsEmpty() const = 0;
    virtual bool IsFull() const=0;//常成员函数,不得修改类中的任何数据成员的值
    virtual int getSize() const=0;//计算栈中的元素个数
    };
3.1 顺序栈的类定义
#include<assert.h> //断言。满足断言中参数的条件则继续执行,不满足则终止程序的执行
#include<iostream.h>
#include "Stack.h"
const int stackIncreament=20;//栈溢出扩展空间增量
template<class T>
class SeqStack: public Stack<T>{
public:
	SeqStack(int sz=50);
    ~SeqStack(){delete[] elements;}
    void Push(const T& x);
    bool Pop(T& x);
    bool getTop(T& x);
    bool IsEmpty()const {return (top==-1)?true:false}
    bool IsFull()const {return (top=maxSize-1)?true:false}
    int getSize()const {return top+1;}
    void MakeEmpty(){top=-1;}
    friend ostream& ope
  • 1
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值