【数据结构】顺序栈

1、基本概念

栈只是对表插入和删除操作的位置进行了限制,并没有限定插入和删除操作进行的时间

2、栈的顺序存储结构及实现

进栈:top加1
出栈:top减1
栈空:top= -1
栈满:top= MAX_SIZE-1

3、顺序栈的声明

const  int  MAX_SIZE=100;
template  <class T>
class  seqStack
{
    public:
        seqStack ( ) ;
        ~seqStack ( );
        void  Push ( T  x );
        T   Pop ( );
        T   GetTop ( );
        bool  Empty ( );
    private:
        T  data[MAX_SIZE];
        int  top;
}

4、入栈

template <class T>
void  seqStack<T>::Push ( T  x)
{
     if (top==MAX_SIZE-1)  throw  “溢出”;
     top++;
     data[top]=x;
 } 

5、判断是否是空栈

template <class T>
bool  seqStack<T>::Empty ()
{
     if (top==-1)  
         return true;
     return false;
 } 

6、取栈顶

template <class T>
T  seqStack<T>::GetTop ( )
{
    if (Empty()) throw  ”空栈” ;
    return data[top];
} 

7、出栈

template  <class  T>
T  seqStack<T>:: Pop ( )
{
    if (top==-1)  throw  “溢出”; 
    x=data[top];
     top--;
    return  x;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值