• <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.¢%

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

            類模板實現(xiàn)堆棧-VC編程

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

            采用了三種實現(xiàn)方法:

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

            2、使用STL的vector(Vector_Stack 堆棧數(shù)組可動態(tài)變化)

            3、使用STL的list(List_Stack 堆棧數(shù)組可動態(tài)變化)


            以下是stack.h的頭文件,所有接口函數(shù)都寫為內(nèi)聯(lián),因此沒有實現(xiàn)文件。
            正在裝載數(shù)據(jù)……


            #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


            文章轉(zhuǎn)載自『幽月's Blog』

            波多野结衣中文字幕久久| 久久久久国产成人精品亚洲午夜| 亚洲午夜久久久影院| 久久久免费精品re6| 精品久久人人妻人人做精品| 精品久久人人爽天天玩人人妻| 久久国产精品99国产精| 国产三级观看久久| 久久久久人妻精品一区二区三区| 99久久国产综合精品网成人影院| 伊人久久亚洲综合影院| 亚洲综合婷婷久久| 粉嫩小泬无遮挡久久久久久| 久久综合久久伊人| 99久久综合国产精品二区| 蜜臀av性久久久久蜜臀aⅴ麻豆| 青青草原综合久久大伊人导航| 99国产欧美精品久久久蜜芽| 精品伊人久久大线蕉色首页| 久久久久亚洲精品天堂久久久久久| 99久久精品日本一区二区免费| 久久天天躁狠狠躁夜夜avapp| 久久www免费人成看国产片| 久久国产亚洲精品无码| 亚洲va中文字幕无码久久不卡| 免费精品久久天干天干| 色综合久久88色综合天天 | 久久国产精品-国产精品| 成人国内精品久久久久影院| 久久精品国产亚洲av麻豆色欲 | 一本一道久久综合狠狠老| 亚洲欧洲精品成人久久曰影片| 国产亚洲精午夜久久久久久| 国产精品99久久不卡| 很黄很污的网站久久mimi色| 99久久99久久精品国产片果冻 | 丰满少妇人妻久久久久久| 99久久国语露脸精品国产| 7国产欧美日韩综合天堂中文久久久久| 久久久精品波多野结衣| 国产精品va久久久久久久|