• <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年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            常用鏈接

            留言簿(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 楊彬彬 閱讀(1017) 評論(0)  編輯 收藏 引用 所屬分類: 數據結構
            日本加勒比久久精品| 久久精品国产色蜜蜜麻豆| 久久久久se色偷偷亚洲精品av| 亚洲国产综合久久天堂 | 久久久久亚洲av综合波多野结衣| 国产精品中文久久久久久久| 国产精品禁18久久久夂久 | 99久久精品费精品国产 | 国产成人精品久久免费动漫| 久久婷婷五月综合成人D啪| 亚洲日本va中文字幕久久| 久久久久国产一区二区| 国产精品美女久久久m| 亚洲午夜久久久久久久久久| 久久精品国产亚洲7777| 99久久免费国产特黄| 久久人人爽人人爽人人av东京热 | 国产精品久久久久久久久软件| 久久99国产综合精品| 亚洲国产欧美国产综合久久| 久久综合一区二区无码| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 伊人久久五月天| 麻豆久久| 三级韩国一区久久二区综合| 国内精品久久久久国产盗摄| 久久噜噜电影你懂的| 精品国产一区二区三区久久| 嫩草伊人久久精品少妇AV| 狠狠色丁香久久婷婷综合| 一本色道久久综合狠狠躁篇 | 2020国产成人久久精品| 亚洲国产精品无码久久九九| 久久婷婷五月综合色99啪ak| 欧洲性大片xxxxx久久久| 久久久久久久久久免免费精品| 久久福利片| 伊人久久国产免费观看视频| 久久精品国产免费观看| 久久久av波多野一区二区| 99久久精品国产高清一区二区|