• <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>
            隨筆 - 8  文章 - 26  trackbacks - 0
            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            常用鏈接

            留言簿(5)

            隨筆檔案

            文章分類

            文章檔案

            相冊

            C++語言

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             1//數據結構隊列簡單實現(循環隊列)
             2#ifndef QUEUE_H
             3#define QUEUE_H
             4
             5template<class T>
             6class Queue
             7{
             8public:
             9    Queue(int maxsize=50); 
            10    virtual ~Queue();
            11    bool IsFull(){return (rear+1)%MaxSize==front?true:false;}//滿?
            12    bool IsEmpty(){return front==rear?true:false;};//空?
            13    Queue<T>& Push(const T& val);//向隊尾插入元素
            14    Queue<T>& Pop(T& e);//從堆頭刪除元素
            15    int Size(){return _Size;};//返回隊列元素個數
            16    T& Front();//返回對頭元素
            17    T& Back();//返回隊尾元素
            18    
            19private:
            20    T *data;
            21    int front,rear;
            22    int MaxSize;
            23    int _Size;
            24}
            ;
            25//------------------------------------------------
            26template<class T>
            27Queue<T>::Queue(int maxsize)
            28{
            29    data=new T[maxsize+1];
            30    MaxSize=maxsize+1;
            31    front=rear=_Size=0;
            32    
            33}

            34//------------------------------------------------
            35template<class T>
            36Queue<T>::~Queue()
            37{
            38    delete[] data;
            39}

            40//------------------------------------------------
            41template<class T>
            42Queue<T>& Queue<T>::Push(const T& val)
            43{
            44    if(IsFull()) throw exception("隊列已滿");
            45    rear=(rear+1)%MaxSize;
            46    data[rear]=val;
            47    _Size++;
            48    return *this;
            49}

            50//------------------------------------------------
            51template<class T>
            52Queue<T>& Queue<T>::Pop(T& e)
            53{
            54    if(IsEmpty()) throw exception("隊列已空");
            55    front=(front+1)%MaxSize;
            56    e=data[front];
            57    _Size--;
            58    return *this;
            59}

            60//------------------------------------------------
            61template<class T>
            62T& Queue<T>::Front()
            63{
            64    if(IsEmpty()) throw exception("隊列已空");
            65    return data[(front+1)%MaxSize];
            66    
            67}

            68//------------------------------------------------
            69template<class T>
            70T& Queue<T>::Back()
            71{
            72    if(IsEmpty()) throw exception("隊列已空");
            73    return data[rear];
            74    
            75}

            76#endif
            posted on 2008-09-19 19:52 楊彬彬 閱讀(1008) 評論(0)  編輯 收藏 引用 所屬分類: 數據結構
            国产精品美女久久久免费| 国产精品乱码久久久久久软件| 一本一道久久综合狠狠老| 久久综合亚洲欧美成人| 久久久久久国产精品无码超碰| 国产精品va久久久久久久| 久久综合色老色| 国产精品美女久久久m| 久久久精品国产Sm最大网站| 久久综合噜噜激激的五月天| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 久久精品国产亚洲AV香蕉| 日本免费一区二区久久人人澡 | 色综合久久久久综合体桃花网 | 99精品久久久久中文字幕| 久久精品女人天堂AV麻| 亚洲第一极品精品无码久久| 国产精品99久久久久久宅男| 成人国内精品久久久久一区| 无码乱码观看精品久久| 亚洲嫩草影院久久精品| 久久99精品国产麻豆| 精品熟女少妇AV免费久久| 久久伊人色| 日本高清无卡码一区二区久久| 久久青青草原国产精品免费 | 久久久久99精品成人片三人毛片| 久久久亚洲欧洲日产国码二区 | 国产精品99久久精品爆乳| 国产亚洲欧美精品久久久| 久久99久国产麻精品66| 思思久久好好热精品国产 | 狠狠狠色丁香婷婷综合久久俺| 久久精品国产亚洲αv忘忧草 | 亚洲乱码精品久久久久..| 性做久久久久久久久浪潮| 亚洲精品无码久久久| 伊人色综合九久久天天蜜桃| 久久只有这里有精品4| 国内精品久久久久影院老司| 久久久久青草线蕉综合超碰|