泛型栈

class MyStack<T>
    {
        T[] StackArray;
        int StackPointer = 0;
        public void Push(T x)
        {
            if (!IsStackFull)
            {
                StackArray[StackPointer++] = x;
            }
        }

        public T Pop()
        {
            return (!IsStackEmpty) ? StackArray[--StackPointer] : StackArray[0];
        }


        const int MaxStack = 10;
        bool IsStackFull
        {
            get { return StackPointer >= MaxStack; }

        }

        bool IsStackEmpty
        {
            get
            {
                return StackPointer <= 0;
            }
        }

        public MyStack()
        {
            StackArray = new T[MaxStack];

        }
        public void Print()
        {
            for (int i =  StackPointer-1; i >=0; i--)
            {
                Console.WriteLine(StackArray[i]);
            }
        }
    }
原文地址:https://www.cnblogs.com/lumang/p/4550157.html