栈的基本操作

栈的特点:先进后出

#include<iostream>
#include<assert.h>
using namespace std;

template<class T>
class Stack
{
public:
    Stack(size_t capacity = 10)//构造函数
        :_capacity(capacity)
        ,_size(0)
    {
        _pData=new T[capacity];
    }
    Stack(const Stack<T>& s)//拷贝构造函数
        :_pData(NULL)
        ,_size(s.Size())
        ,_capacity(s._capacity)
    {
        _pData=new T[capacity];
        for(size_t i=0;i<s.Size();i++)
        {
            _pData[i]=s._pData[i];
        } 
    }
    Stack<T>& operator=(const Stack<T>& s)//赋值运算符重载
    {
        if (this != &s)  
       {  
            _capacity = _capacity * 2 + 3;  
            T * tmp = new int[s._capacity];  
            for (size_t i = 0; i < s._size; ++i)  
            {  
                _pData[i] = s._pData[i];  
            }  
            delete _pData;  
            _pData = tmp;  
            _size = s._size;  
            _capacity = s._capacity;  
        }  
        return *this;  
    }
    void Push(const T& x)//入栈
    {
        _CheckCapacity();//检测栈的容量
        _pData[_size++]=x;
    }
    void Pop()//出栈
    {
        assert(!Empty());
        --_size;
    }
    size_t Size()const//栈中元素的个数
    {
        return _size;
    }
    T& Top()//取栈顶元素
    {
        return _pData[_size-1];
    }
    const T& Top()const
    {
        return _pData[_size-1];
    }
    bool Empty()//判断栈是否空
    {
        return 0==_size;
    }

private:
    void _CheckCapacity()//检测栈的容量
    {
        if(_size>=_capacity)
        {
            // 申请空间
            T* temp = new int[2*_capacity+3];           
            // 拷贝元素
            //memcpy(); 缺点:浅拷贝 有点:速度快
            //memcopy(temp,_pData,sizeof(T)*_size);
            for(size_t i=0;i<_size;i++)
            {
                temp[i]=_pData[i];
            }         
            // 释放旧空间
            delete[] _pData;
            // 指向新空间
            _pData=temp;
            _capacity *= 2;

        }
    }
private:
    T* _pData;
    size_t _capacity;
    size_t _size;
};

int main()
{
    Stack<int> s;
    s.Push(1);
    s.Push(2);
    s.Push(3);
    s.Push(4);
    s.Push(5);
    s.Push(6);
    s.Push(7);
    s.Push(8);
    s.Push(9);
    s.Push(10);
    cout<<s.Size()<<endl;
    cout<<s.Empty()<<endl;
    s.Pop();
    cout<<s.Size()<<endl;
    cout<<s.Top()<<endl;

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值