顺序栈的模板类实现

从数据结构的角度看,栈也是线性表的一种,其特殊性在于栈其基本的操作还是依靠线性表实现的。

栈只允许在栈顶进行插入和删除操作。
栈的存储方式也分顺序栈和链栈两种,个人觉得既然只运行对栈顶进行操作,链栈没什么意义啊。

#ifndef STACK_H_
#define STACK_H_
template <typename T>
class Stack
{
public:
    Stack(int size = Stack_init_size);
    //构造函数
    ~Stack();
    Stack(const Stack<T> &s);
    //拷贝构造函数
    const Stack<T>& operator=(const Stack<T> &s);
    //赋值构造函数
    void ClearStack();
    //清空栈
    bool StackEmpty();
    //若栈为空返回TRUE否则返回FALSE
    int StackLength();
    //返回栈的长度,即入栈元素个数
    bool GetTop(T &elem);
    //若栈不空,用elem返回栈顶元素,并返回true,否则返回ERROR
    void Push(T elem);
    //插入元素elem为新的栈顶元素
    bool Pop(T &elem);
    //若栈不为空,则删除栈顶元素,用elem返回其值,并返回true,否则返回error

private:
    T *base;
    T *top;
    int m_size;
    enum StackSize
    {
        Stack_init_size = 100,          //存储空间初始分配量
        Stack_incerement = 10            //存储空间分配增加量
    };
};
template <typename T>
Stack<T>::Stack(int size)
{
    base = new T[Stack_init_size];
    if (base==NULL)
    {
        exit(1);
    }
    top = base;
    m_size = size;
}

template <typename T>
Stack<T>::Stack(const Stack<T> &s)
{
    base = new T[s.m_size];
    if (base == NULL)
    {
        exit(1);
    }
    top = base;
    m_size = s.m_size;
    T * p1 =s.base ;
    T * p2 = base;
    while (p1!=s.top)
    {
        *p2 = *p1;
        p1++;
        p2++;
    }
    top = p2;

}
template <typename T>
const Stack<T>& Stack<T>::operator=(const Stack<T> &s)
{
    delete[] base;
    base = new T[s.m_size];
    if (base == NULL)
    {
        exit(1);
    }
    top = base;
    m_size = s.m_size;
    T * p1 = s.base;
    T * p2 = base;
    while (p1 != s.top)
    {
        *p2 = *p1;
        p1++;
        p2++;
    }
    top = p2;
    return *this;
}

template <typename T>
Stack<T>::~Stack()
{
    delete[] base;
}


template <typename T>
int Stack<T>::StackLength()
{
    int n = 0;
    T * p = top;
    while (p!= base)
    {
        n++;
        p--;
    }
    return n;
}

template <typename T>
void Stack<T>::ClearStack()
{

    while (top != base)
    {
        top--;
        *top = 0;

    }

}
template <typename T>
bool Stack<T>::StackEmpty()
{
    if (top == base)
    {
        return true;
    }
    return false;
}
template <typename T>
bool Stack<T>::GetTop(T &elem)
{
    if (StackEmpty())
    {
        return false;
    }
    else
    {

        top--;
        elem = *top;
        *top = 0;
        return true;
    }

}
template <typename T>
void Stack<T>::Push(T elem)
{
    int size_increment;
    if (top - base>Stack_init_size)
    {
        m_size = m_size + Stack_incerement;
        T *temp = new T[m_size];
        T *p = base;
        T *q = temp;
        while ((p + 1) != top)
        {
            *q = *p;
            q++;
            p++;
        }
        delete[] base;
        base = temp;
        *q = elem;
        q++;
    }
    else
    {
        *top = elem;
        top++;
    }

}

template <typename T>
bool Stack<T>::Pop(T &elem)
{
    if (top == base)
    {
        return false;
    }
    top--;
    elem = *top;
    *top = 0;
    return true;
}

#endif

提醒一下 template macro auto 等都需要全部在头文件中可见,不可以将声明和定义独立编译。

你可能感兴趣的:(数据结构,栈)