您的位置:首页 > 编程语言 > C语言/C++

顺序栈的c++实现

2015-06-16 15:57 453 查看
栈的定义以及对栈的操作在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");
}


运行结果

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: