首页 > 其他 > 详细

堆栈stack源码

时间:2019-03-25 12:12:21      阅读:124      评论:0      收藏:0      [点我收藏+]
/**
stack.h

*****/

#include <iostream>
using namespace std;

template <class T>
class Stack
{
public:
Stack(int maxsize = 10);
~Stack(){delete stack;}

T Top();
void push(const T & x);
void pop();
bool empty();

private:
int top;
T * stack;
int maxtop;
};

/**
stack.cpp

**/

#include "stack.h"
template <class T>
Stack::Stack(int maxsize)
{
maxtop = maxsize;
top = -1;
stack = new T[maxsize];
}

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

template <class T>
T Stack::top()
{
return stack[top];
}

template <class T>
void Stack::push (const T & x)
{
top++;
stack[top] = x;
}

template <class T>
void Stack::pop()
{
top--;
}

堆栈stack源码

原文:https://blog.51cto.com/wenxuehui/2368519

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!