• <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』

            777午夜精品久久av蜜臀| 久久99热这里只有精品国产| 97精品依人久久久大香线蕉97| 久久人人爽人人爽人人片AV东京热| 影音先锋女人AV鲁色资源网久久| 无码国内精品久久人妻蜜桃 | 婷婷久久香蕉五月综合加勒比| 欧美一区二区三区久久综合 | 午夜精品久久久久久毛片| 狠狠色丁香久久婷婷综| 久久五月精品中文字幕| 97精品国产91久久久久久| 欧美与黑人午夜性猛交久久久| 亚洲国产精品久久久天堂| 久久久久国产一区二区三区| 久久久久成人精品无码中文字幕| 久久综合五月丁香久久激情| 久久99精品国产99久久| 一本久久知道综合久久| 亚洲精品综合久久| 一级做a爰片久久毛片人呢| 午夜精品久久久久久毛片| 成人综合久久精品色婷婷| 久久国产精品视频| 久久亚洲精品中文字幕三区| 99精品国产99久久久久久97| 日韩影院久久| 午夜精品久久久久久| 久久精品三级视频| 久久福利片| 久久99精品久久久久久水蜜桃| 国产一级持黄大片99久久| 久久99毛片免费观看不卡| 97久久香蕉国产线看观看| 精品久久人妻av中文字幕| 亚洲香蕉网久久综合影视| 少妇精品久久久一区二区三区| 777午夜精品久久av蜜臀| 色综合久久久久综合体桃花网 | 亚洲精品无码久久久久去q| 蜜桃麻豆WWW久久囤产精品|