zoukankan      html  css  js  c++  java
  • 顺序栈

     1 //Stack.h
     2 
     3 #ifndef STACK_H
     4 #define STACK_H
     5 
     6 #define OK 1
     7 #define ERROR 0
     8 typedef int Status;
     9 typedef int SElemType;
    10 #define STACK_INIT_SIZE 100
    11 #define STACKINCREMENT 10
    12 typedef struct {
    13     SElemType *base;//栈底指针
    14     SElemType *top; //栈顶指针
    15     int stacksize;  //当前已分配的存储空间
    16 }SqStack;
    17 Status InitStack(SqStack &S);
    18 Status DestoryStack(SqStack &S);
    19 Status ClearStack(SqStack &S);
    20 Status StackEmpty(SqStack &S);
    21 int StackLength(SqStack S);
    22 Status GetTop(SqStack S, SElemType &e);
    23 Status Push(SqStack &S, SElemType e);
    24 Status Pop(SqStack &S, SElemType &e);
    25 Status StackTraverse(SqStack S);
    26 
    27 #endif
    //Stack.cpp
    
    #include"Stack.h"
    #include<iostream>
    #include<cstdlib>
    using namespace std;
    
    Status InitStack(SqStack &S)
    {
        S.base = (SElemType *)malloc(sizeof(SElemType)*STACK_INIT_SIZE);
        if (!S.base)
            exit(OVERFLOW);
        S.top = S.base;
        S.stacksize = STACK_INIT_SIZE;
        return OK;
    }
    Status DestoryStack(SqStack &S)
    {
        S.top = S.base;
        free(S.base);
        S.stacksize = 0;
        return OK;
    }
    Status ClearStack(SqStack &S)
    {
        S.top = S.base;
        return OK;
    }
    Status StackEmpty(SqStack &S)
    {
        if (S.top == S.base)
            return OK;
        return ERROR;
    }
    int StackLength(SqStack S)
    {
        return (S.top - S.base)/sizeof(SElemType);
    }
    Status GetTop(SqStack S, SElemType &e)
    {
        if (S.top == S.base)
            return ERROR;
        e = *(S.top - 1);
        return OK;
    }
    Status Push(SqStack &S, SElemType e)
    {
        if (S.top - S.base >= S.stacksize)//追加栈的存储空间
        {
            S.base = (SElemType *)realloc(S.base, (S.stacksize + STACKINCREMENT) * sizeof(SElemType));
            if (!S.base)
                exit(OVERFLOW);
            S.top = S.base + S.stacksize;
            S.stacksize += STACKINCREMENT;
        }
        *S.top++ = e;
        return OK;
    }
    Status Pop(SqStack &S, SElemType &e)
    {
        if (S.top == S.base)
            return ERROR;
        e = *--S.top;      //*S.top并没有指向元素,S.top指向栈顶元素的下一个位置
        return OK;
    }
    Status StackTraverse(SqStack S)
    {
        if (S.top == S.base)
        {
            cout << "栈为空"<<endl;
            return ERROR;
        }
        SElemType *p = S.base;
        cout << "栈底 |";
        for (p = S.base; p < S.top; p++)
            cout << *p<<" ";
        cout << endl;
        return OK;
    }
    //Main.cpp
    
    #include"Stack.h"
    #include<iostream>
    using namespace std;
    
    int main()
    {
        SqStack S;
    
        SElemType temp = 0;
        int choose = 10;
        
        while (choose != 0)
        {
            switch (choose)
            {
            case 1:
                InitStack(S);
                if(S.base)
                    cout << "构造栈成功" << endl;
                break;
            case 2:
                DestoryStack(S);
                cout << "销毁栈成功" << endl;
                break;
            case 3:
                ClearStack(S);
                cout << "清空栈成功" << endl;
                break;
            case 4:
                if (StackEmpty(S))
                    cout << "栈为空"<<endl;
                else
                    cout << "栈不为空"<<endl;
                break;
            case 5:
                cout<<StackLength(S);
                break;
            case 6:
                GetTop(S,temp);
                cout << "栈顶元素为:"<<temp<<endl;
                break;
            case 7:
                cout << "输入要插入的元素: ";
                cin >> temp;
                Push(S, temp);
                break;
            case 8:
                if (S.base == S.top)
                    cout << "栈已空,无法弹出元素" << endl;
                else
                {
                    Pop(S, temp);
                    cout <<"弹出 "<< temp<<endl;
                }
                break;
            case 9:
                StackTraverse(S);
                break;
            default:
                cout << "|**顺序栈**|" << endl;
                cout << "|1.构造栈 *|" << endl;
                cout << "|2.销毁栈 *|" << endl;
                cout << "|3.置空栈 *|" << endl;
                cout << "|4.栈空否 *|" << endl;
                cout << "|5.栈长度 *|" << endl;
                cout << "|6.栈顶值 *|" << endl;
                cout << "|7.插入栈 *|" << endl;
                cout << "|8.弹出栈 *|" << endl;
                cout << "|9.遍历栈 *|" << endl;
                cout << "|0.退出    |" << endl;
                break;
            }    
            cout << "input 0~9" << endl;
            cin >> choose;
        }
        system("pause");
        return 0;
    }
  • 相关阅读:
    171-滑动窗口问题
    170-133. 克隆图
    169-150. 逆波兰表达式求值
    windows相对路径设置与取消小工具[提效]
    Sword 38
    Sword 33
    Sword 28
    Sword 26
    Sword 12
    Sword 07
  • 原文地址:https://www.cnblogs.com/sgawscd/p/10198746.html
Copyright © 2011-2022 走看看