数据结构与算法——顺序栈

今天总结栈的顺序存储结构

什么是栈?

是一种线性表,其特点是限定尽在表尾进行插入和删除操作,表尾栈一段也叫栈顶,另一端就是栈底了。既然栈是线性表,那么栈也就有两种存储数据的方式,顺序存储和链式存储。今天实现的是顺序存储的栈,也就顺序栈。

图示(来自百度图片):

数据结构与算法——顺序栈_第1张图片

顺序栈的实现:

栈的顺序存储还是比较简单的,就是对数组进行操作。

#include 

using namespace std;
const int StackSize = 1024; //栈的最大高度
template 
class SeqStack {
public:
    SeqStack() {
        top = -1; //空栈时
    }
    void PushStack(T x); //将元素x入栈
    T PopStack(); //出栈
    T GetTop(); //得到栈顶元素
    bool IsEmpty(); //判断栈是否为空
    void PrintStack();
private:
    int top; //栈顶指针
    T data[StackSize];
};

template 
void SeqStack::PushStack(T x) {
    data[++top] = x;  //将x入栈 将top+1
}


template
void SeqStack::PrintStack() {
    if(IsEmpty()) cout<<"栈为空"<=0;i--) {
        cout<
T SeqStack::PopStack() {
    if(IsEmpty()) cout<<"栈为空";
    return data[top--];  //返回栈顶元素后 将指针下移
}

template
T SeqStack::GetTop() {
    if(IsEmpty()) {
            return -1;
    }else {
        return data[top];
    }

}
//判断栈是否为空 就是判断top指针是否等于-1
template
bool SeqStack::IsEmpty() {
    if(top==-1)
        return true;
    else
        false;
}
int main()
{
    SeqStack stack;
    for(int i=0;i<5;i++) {
        stack.PushStack(i);
    }
    cout<<"栈内元素:(按照栈顶到栈底顺序)"<


你可能感兴趣的:(数据结构与算法)