顺序栈的c++实现

栈的定义以及对栈的操作在mystack.h中实现

#ifndef MYSTACK_H
#define MYSTACK_H
template<class T>
class Mystack
{
public:
    Mystack(int stackcapacity);
    ~Mystack();
    bool Isempty();
    void Top();
    void Push(T item);
    void Pop();
private:
    T *stack;
    int top;
    int capacity;

};
//利用构造函数初始化栈的容量
template <class T>
Mystack<T>::Mystack(int stackcapacity)  
{
  capacity= stackcapacity;
  stack=new T[capacity];
  top=-1;
} 

//利用析构函数清除栈
template <class T>
Mystack<T>::~Mystack()     
{
 delete []stack;

}

//元素进栈
template <class T>
void Mystack<T>::Push(T item)
{
    if(top==capacity-1)
    {
     Changsize(stack,capacity,2*capacity);
     capacity=2*capacity;
    }
    stack[++top]=item;
}

//访问栈顶元素
template <class T>
inline void Mystack<T>::Top()
{
  if(!Isempty())
  {
   cout<<"栈顶元素为:"<< stack[top]<<endl;
  }
  else
  {
  cout<<"此时栈为空"<<endl;
  }
}

//改变栈的容量
template <class T>
void Changsize(T *a,int oldsize,int newsize)

{
  if(newsize<0) throw "new length must be >=0";
  T *temp=new T[newsize];
  int number=min(oldsize,newsize);
  std::copy(a,a+number,temp);
  delete []a;
  a=temp;


}

//栈顶元素出栈
template <class T>
void Mystack<T>::Pop()
{ 
    if(!Isempty())
    top=top-1;
}

template <class T>
bool Mystack<T>::Isempty()
{
 return top==-1;
}
#endif 

主函数如下:


// main.cpp代码

#include "mystack.h"
#include <iostream>
using namespace std;

int main()
{
  Mystack<int> ST(20);
  ST.Push(11);
  ST.Push(12);
  ST.Push(13);
  ST.Top();

  ST.Pop();
  ST.Pop();
  ST.Top();

  ST.Pop();
  ST.Top();

  system("pause");
}

运行结果

这里写图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值