• <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)  編輯 收藏 引用 所屬分類: 數據結構
            久久精品国产99久久久古代| 国产高潮国产高潮久久久| 亚洲国产成人久久一区WWW| 一本久久精品一区二区| 久久狠狠高潮亚洲精品| 国产日韩久久免费影院| 国产99久久久国产精品小说| 国产成人久久精品激情| 热久久国产欧美一区二区精品| 欧美日韩精品久久久久| 99久久无码一区人妻a黑| 久久精品国产亚洲精品| 色欲综合久久中文字幕网| 国产精品成人久久久久三级午夜电影 | 色综合合久久天天综合绕视看| 日韩欧美亚洲综合久久影院Ds| 欧美黑人又粗又大久久久| 久久久久女教师免费一区| 国产亚洲欧美成人久久片| 久久人人爽人人人人爽AV| 国产国产成人久久精品| 精品久久久无码人妻中文字幕豆芽 | 99久久夜色精品国产网站| 精品久久久久久国产牛牛app| 日产精品久久久久久久性色| 欧美日韩精品久久久久| 天天做夜夜做久久做狠狠| 国产亚州精品女人久久久久久 | 久久精品国产一区二区| 精品久久久久久无码人妻蜜桃| 色综合久久综合中文综合网| 亚洲国产精品18久久久久久| 久久婷婷五月综合国产尤物app| 色综合久久中文字幕综合网| 久久综合色区| 久久亚洲精品国产精品婷婷| 亚洲人成无码www久久久| 热综合一本伊人久久精品| 思思久久99热免费精品6| 亚洲国产精品无码久久久久久曰| 亚洲国产成人久久一区WWW|