zoukankan      html  css  js  c++  java
  • 【1】栈的基本概念

    (1)栈是限定仅在表尾进行插入和删除操作的线性表。所谓的表尾是指栈顶,而不是栈底。

    (2)栈是后进先出的线性表。

    (3)把允许插入和删除的一端称为栈顶,另一端称为栈底。

    (4)不含任何元素的栈称为空栈。 判定条件为top等于-1。

    (5)栈是一个线性表,栈元素具有线性关系。

    【2】进栈出栈变化形式

    进栈出栈变化形式如下图:

    【3】栈的实现代码

    顺序栈的实现:

      1 // SeqStack.h
      2 // 顺序栈的实现
      3 #pragma  once
      4 
      5 #include <assert.h>
      6 #include <string.h>
      7 
      8 #define   STACKSIZE  100
      9 
     10 template<class Type>
     11 class   SeqStack
     12 {
     13     private:
     14         Type *data;
     15         int  top;
     16         int  size;
     17     public:
     18         SeqStack(int  sz = STACKSIZE);
     19         ~SeqStack();
     20         SeqStack(const SeqStack<Type> &st);
     21         SeqStack<Type> operator=(const SeqStack<Type> &st);
     22         bool Push(const Type &item);
     23         bool Pop(Type &item);
     24         bool GetTop(Type &item);
     25         bool IsEmpty() const;
     26         bool IsFull() const;
     27         void MakeEmpty();
     28         int  StackLen();
     29         void PrintStack();
     30 };
     31 
     32 template<class Type>
     33 SeqStack<Type>::SeqStack(int sz)
     34 {
     35     size = sz > STACKSIZE ? sz : STACKSIZE;
     36     data = new Type[size];
     37     assert(data!=NULL);
     38     for (int i = 0; i < size; i++)
     39     {
     40         data[i] = NULL;
     41     }
     42     top = -1;
     43 }
     44 template<class Type>
     45 SeqStack<Type>::~SeqStack()
     46 {
     47     if (data != NULL)
     48     {
     49         delete []data;
     50         data = NULL;
     51     }
     52     size = 0;
     53     top = -1;
     54 }
     55 template<class Type>
     56 SeqStack<Type>::SeqStack(const SeqStack<Type> &st)
     57 {
     58     size = st.size;
     59     data = new Type[size];
     60     assert(data != NULL);
     61     memcpy(data, st.data, (st.top + 1)*sizeof(Type));
     62     top = st.top;
     63 }
     64 template<class Type>
     65 SeqStack<Type>  SeqStack<Type>::operator=(const SeqStack<Type> &st)
     66 {
     67     if (this != &st)
     68     {
     69         delete []data;
     70         size = st.size;
     71         data = new Type[size];
     72         assert(data != NULL);
     73         memcpy(data, st.data, (st.top + 1)*sizeof(Type));
     74         top = st.top;
     75     }
     76     return *this;
     77 }
     78 template<class Type>
     79 bool SeqStack<Type>::Push(const Type &item)
     80 {
     81     if (top < size-1)
     82     {
     83         data[++top] = item;
     84         return true;
     85     }
     86     else
     87     {
     88         return false;
     89     }
     90 }
     91 template<class Type>
     92 bool SeqStack<Type>::Pop(Type &item)
     93 {
     94     if (top >= 0)
     95     {
     96         item = data[top--];
     97         return true;
     98     }
     99     else 
    100     {
    101         return false;
    102     }
    103 }
    104 template<class Type>
    105 bool SeqStack<Type>::GetTop(Type &item)
    106 {
    107     if (top >= 0)
    108     {
    109         item = data[top];
    110         return true;
    111     }
    112     return false;
    113 }
    114 template<class Type>
    115 bool SeqStack<Type>::IsEmpty() const
    116 {
    117     return -1 == top;
    118 }
    119 template<class Type>
    120 bool SeqStack<Type>::IsFull() const
    121 {
    122     return top >= size - 1;
    123 }
    124 template<class Type>
    125 void SeqStack<Type>::MakeEmpty()
    126 {
    127     top = -1;
    128 }
    129 template<class Type>
    130 int SeqStack<Type>::StackLen()
    131 {
    132     return  top + 1;
    133 }
    134 template<class Type>
    135 void SeqStack<Type>::PrintStack()
    136 {
    137     for (int i = top; i >= 0; i--)
    138     {
    139         cout << data[i] << "  ";
    140     }
    141     cout << endl;
    142 }
    View Code


    Good  Good  Study, Day  Day  Up.

    顺序  选择  循环  总结

  • 相关阅读:
    python之np.tile()
    python中easydict的简单使用
    Python字典(Dictionary)update()方法
    Flutter学习之导航与数据的传输
    Flutter学习之重叠布局
    Flutter学习之重叠布局
    Flutter学习之纵向布局
    Flutter学习之纵向布局
    Flutter学习之GridView
    Flutter学习之GridView
  • 原文地址:https://www.cnblogs.com/Braveliu/p/3452693.html
Copyright © 2011-2022 走看看