• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            類模板實現堆棧-VC編程

            Posted on 2009-10-06 01:55 S.l.e!ep.¢% 閱讀(516) 評論(0)  編輯 收藏 引用 所屬分類: C++
            類模板實現堆棧-VC編程
            2008-05-29 08:16:40

            采用了三種實現方法:

            1、自己定義數組(Stack 堆棧數組大小不能動態增加)

            2、使用STL的vector(Vector_Stack 堆棧數組可動態變化)

            3、使用STL的list(List_Stack 堆棧數組可動態變化)


            以下是stack.h的頭文件,所有接口函數都寫為內聯,因此沒有實現文件。
            正在裝載數據……


            #ifndef ___STACK_H___
            #define ___STACK_H___

            #include <windows.h>
            #include <vector>

            using namespace std;

            template<class T,int size = 100>
            class Stack
            {
            public:
            Stack():top(0){}
            ~Stack(){};

            int Push(T& data)
            {
            if (top >= size)
            {
            return top;
            }
            stack[top ] = data;
            return top;
            }
            int Pop(T* pData)
            {
            if (top <= 0)
            {
            return -1;
            }
            *pData = stack[--top];
            return 0;
            }
            int Size()
            {
            return top;
            }
            int Clear()
            {
            top = 0;
            return 0;
            }
            int Peek(T* pData)
            {
            *pData = stack[top];
            return 0;
            }
            BOOL IsEmpty()
            {
            return (top > 0 ? FALSE : TRUE);
            }
            protected:
            private:
            T stack[size];
            int top;
            };


            template<class T>
            class Vector_Stack
            {
            public:
            Vector_Stack(){}
            ~Vector_Stack(){};

            int Push(T& data)
            {
            vstack.push_back(data);
            return vstack.size();
            }
            int Pop(T* pData)
            {
            if (vstack.empty())
            {
            *pData = 0;
            return -1;
            }
            else
            {
            *pData = vstack.back();
            vstack.pop_back();
            return 0;
            }
            }
            int Size()
            {
            return vstack.size();
            }
            int Clear()
            {
            vstack.clear();
            return 0;
            }
            int Peek(T* pData)
            {
            *pData = vstack.back();
            return 0;
            }
            BOOL IsEmpty()
            {
            return (vstack.empty() ? TRUE : FALSE);
            }
            protected:
            private:
            vector<T> vstack;
            };

            template<class T>
            class List_Stack
            {
            public:
            List_Stack(){}
            ~List_Stack(){};

            int Push(T& data)
            {
            lstack.push_back(data);
            return lstack.size();
            }
            int Pop(T* pData)
            {
            if (lstack.empty())
            {
            *pData = 0;
            return -1;
            }
            else
            {
            *pData = lstack.back();
            lstack.pop_back();
            return 0;
            }
            }
            int Size()
            {
            return lstack.size();
            }
            int Clear()
            {
            lstack.clear();
            return 0;
            }
            int Peek(T* pData)
            {
            *pData = lstack.back();
            return 0;
            }
            BOOL IsEmpty()
            {
            return (lstack.empty() ? TRUE : FALSE);
            }
            protected:
            private:
            vector<T> lstack;
            };

            #endif

            檢驗代碼:

            // 模板(棧).cpp : Defines the entry point for the console application.
            //

            #include "stdafx.h"
            #include "stack.h"

            #include <vector>
            #include <iostream>

            using namespace std;

            int main(int argc, char* argv[])
            {
            /************************************************************************/
            /* Stack */
            /************************************************************************/
            cout<<"********** Stack **********"<<endl;

            int i,nSize;
            int data;
            const int size = 3;
            Stack<int,size> intStack;

            cout<<"set stack size=3"<<endl;

            for (i=0;i<3;i )
            {
            data = (i 1)*100;
            intStack.Push(data);
            cout<<"push "<<data<<endl;
            }
            cout<<"size="<<intStack.Size()<<endl;

            for (i=0;i<size 1;i )
            {
            if (!intStack.Pop(&data))
            {
            cout<<"pop data:"<<data<<endl;
            }
            }
            cout<<"size="<<intStack.Size()<<endl<<endl;

            /************************************************************************/
            /* Vector_Stack */
            /************************************************************************/
            cout<<"********** Vector_Stack **********"<<endl;

            Vector_Stack<int> vIntStack;

            for (i=0;i<5;i )
            {
            data = (i 1)*10;
            vIntStack.Push(data);
            cout<<"push "<<data<<endl;
            }
            nSize = vIntStack.Size();
            cout<<"size="<<nSize<<endl;

            for (i=0;i<nSize 1;i )
            {
            vIntStack.Pop(&data);
            cout<<"pop data:"<<data<<endl;
            }
            nSize = vIntStack.Size();
            cout<<"size="<<nSize<<endl;

            cout<<"IsEmpty="<<vIntStack.IsEmpty()<<endl<<endl;

            /************************************************************************/
            /* List_Stack */
            /************************************************************************/
            cout<<"********** List_Stack **********"<<endl;

            List_Stack<int> lIntStack;

            for (i=0;i<5;i )
            {
            data = (i 1)*10;
            lIntStack.Push(data);
            cout<<"push "<<data<<endl;
            }
            nSize = lIntStack.Size();
            cout<<"size="<<nSize<<endl;

            for (i=0;i<nSize 1;i )
            {
            lIntStack.Pop(&data);
            cout<<"pop data:"<<data<<endl;
            }
            nSize = lIntStack.Size();
            cout<<"size="<<nSize<<endl;

            cout<<"IsEmpty="<<lIntStack.IsEmpty()<<endl;

            return 0;
            }


            運行結果為:

            ********** Stack **********
            set stack size=3
            push 100
            push 200
            push 300
            size=3
            pop data:300
            pop data:200
            pop data:100
            size=0

            ********** Vector_Stack **********
            push 10
            push 20
            push 30
            push 40
            push 50
            size=5
            pop data:50
            pop data:40
            pop data:30
            pop data:20
            pop data:10
            pop data:0
            size=0
            IsEmpty=1

            ********** List_Stack **********
            push 10
            push 20
            push 30
            push 40
            push 50
            size=5
            pop data:50
            pop data:40
            pop data:30
            pop data:20
            pop data:10
            pop data:0
            size=0
            IsEmpty=1
            Press any key to continue


            文章轉載自『幽月's Blog』

            精品久久人妻av中文字幕| 欧美麻豆久久久久久中文| 国产精品久久久亚洲| 2020久久精品国产免费| 精品国产综合区久久久久久| 日本国产精品久久| 亚洲日韩中文无码久久| 国产精品一区二区久久国产| 91精品免费久久久久久久久| 2021最新久久久视精品爱| 亚洲精品乱码久久久久久中文字幕 | 国产精品对白刺激久久久| 久久久久久a亚洲欧洲aⅴ| 国产精品中文久久久久久久| 婷婷伊人久久大香线蕉AV| 久久99精品久久久久久野外| 精品人妻伦九区久久AAA片69| 亚洲国产精品人久久| 亚洲va久久久噜噜噜久久| 久久男人中文字幕资源站| 免费观看成人久久网免费观看| 伊人久久大香线蕉综合Av| 久久精品国产亚洲Aⅴ蜜臀色欲| 精品久久久久久久无码| 一本久久a久久精品综合香蕉 | 久久e热在这里只有国产中文精品99| 少妇久久久久久被弄到高潮| 精品久久久久香蕉网| 亚洲国产欧洲综合997久久| 亚洲欧美成人久久综合中文网 | 亚洲v国产v天堂a无码久久| 99国产欧美精品久久久蜜芽| 99精品久久精品一区二区| 久久久久国产精品麻豆AR影院 | 亚洲AV无码1区2区久久| 午夜精品久久影院蜜桃| 久久青青草原精品国产不卡| 99久久精品免费看国产| 亚洲一本综合久久| 欧洲国产伦久久久久久久| 色妞色综合久久夜夜|