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

            大規(guī)模高性能網(wǎng)絡(luò)服務(wù)器編程 大型游戲服務(wù)器編程


            大規(guī)模高性能網(wǎng)絡(luò)服務(wù)器編程 大型游戲服務(wù)器編程 完成端口模型 TCP UDP P2P 網(wǎng)絡(luò)編程

                       C++博客 | 首頁 | 發(fā)新隨筆 | 發(fā)新文章 | 聯(lián)系 | 聚合 | 管理

                          

            STL容器使用之二:deque


            本文原創(chuàng)發(fā)表地址為:http://www.shnenglu.com/kusamba/archive/2010/09/17/126895.html,轉(zhuǎn)載請保留原鏈接,謝謝!


            deque的數(shù)據(jù)結(jié)構(gòu)示意圖:

            技術(shù)要點:
            隨機訪問每個元素,所需要的時間為常量。
            在開頭和末尾增加元素所需時間與元素數(shù)目無關(guān),在中間增加或刪除元素所需時間隨元素數(shù)目呈線性變化。
            可動態(tài)增加或減少元素,內(nèi)存管理自動完成,不提供用于內(nèi)存管理的成員函數(shù)。


            參考代碼:
             1 /************************************************************************
             2 * deque:
             3 *    1, 分塊分配空間,非順序存儲,隨機訪問是通過復(fù)雜的iterator實現(xiàn)
             4 *    2, 在前后插入數(shù)據(jù)時間復(fù)雜度為O(1)
             5 *    3, 迭代器失效:
             6 *       If an element is inserted into an empty sequence, or if an element is 
             7        erased to leave an empty sequence, then iterators earlier returned 
             8        by begin and end become invalid.
             9 
            10        If an element is inserted at the first position of the deque, 
            11        then all iterators, but no references, that designate existing 
            12        elements become invalid.
            13 
            14        If an element is inserted at the end of the deque, then end and all 
            15        iterators, but no references, that designate existing elements become invalid.
            16 
            17        If an element is erased at the front of the deque, only that iterator 
            18        and references to the erased element become invalid.
            19 
            20        If the last element is erased from the end of the deque, only that 
            21        iterator to the final element and references to the erased element become invalid.
            22 
            23        Otherwise, inserting or erasing an element invalidates all iterators and references.
            24 
            25 *    by Kusamba@126.com    http://www.shnenglu.com/kusamba
            26 */
            27 void deque_test()
            28 {
            29     deque<int> dqInt;
            30 
            31     int nSize = dqInt.size();
            32     int nMaxSiz = dqInt.max_size();
            33 
            34     dqInt.resize(100);
            35     dqInt.resize(102);
            36     
            37     /**
            38     * push_back
            39     */
            40     for (int i = 0; i < 10++i)
            41     {
            42         dqInt[i] = i + 1;
            43     }
            44     for (int i = 0; i < 10++i)
            45     {
            46         dqInt.push_back(i + 11);
            47     }
            48 
            49     /**
            50     * insert
            51     */
            52     for (deque<int>::iterator it = dqInt.begin(); it != dqInt.end();)
            53     {
            54         if (*it % 3 == 0//在3的倍數(shù)的元素后面插入100
            55         {
            56             it = dqInt.insert(it + 1100);
            57         } 
            58         else
            59         {
            60             ++it;
            61         }
            62     }
            63 
            64     /**
            65     * erase
            66     */
            67     for (deque<int>::iterator it = dqInt.begin(); it != dqInt.end();)
            68     {
            69         if (*it == 4)
            70         {
            71             it = dqInt.erase(it);
            72         } 
            73         else
            74         {
            75             ++it;
            76         }
            77     }
            78 
            79     /**
            80     * traverse
            81     */
            82     printf("print deque: ");
            83     for (int i = 0; i < dqInt.size(); ++i)
            84     {
            85         printf("%d ", dqInt[i]);
            86     }
            87     printf("\n");
            88 
            89     /**
            90     * pop
            91     */
            92     while (!dqInt.empty())
            93     {
            94         int nItemVal = dqInt.front();
            95         dqInt.pop_front();
            96     }
            97 }


            posted on 2010-09-17 17:19 iKusamba 閱讀(1690) 評論(0)  編輯 收藏 引用 所屬分類: C++技術(shù)

            公告

            導(dǎo)航

            隨筆分類

            最新隨筆

            最新評論

            閱讀排行榜

            无码乱码观看精品久久| 久久久青草久久久青草| 亚洲欧美日韩精品久久亚洲区 | 亚洲午夜久久久久久久久久| 色婷婷综合久久久中文字幕| 国内精品久久久久久麻豆| 热99RE久久精品这里都是精品免费| 久久精品国产免费观看| 久久er热视频在这里精品| 合区精品久久久中文字幕一区| 亚洲AV日韩AV天堂久久| 久久午夜福利电影| 久久婷婷国产麻豆91天堂| 久久伊人五月丁香狠狠色| 国产69精品久久久久99| 色婷婷综合久久久中文字幕| 久久久久99精品成人片| 99精品久久精品一区二区| 2021国产精品久久精品| 久久亚洲精品无码播放| 久久96国产精品久久久| 亚洲日韩中文无码久久| 色综合合久久天天给综看| 久久亚洲国产精品一区二区| 久久不见久久见免费视频7| 久久久这里有精品| 久久婷婷是五月综合色狠狠| 香港aa三级久久三级老师2021国产三级精品三级在 | 国产99久久久久久免费看| 国内精品久久久人妻中文字幕| 欧美一区二区久久精品| 久久精品视频一| 久久久www免费人成精品| 欧美久久天天综合香蕉伊| 久久99精品九九九久久婷婷| 草草久久久无码国产专区| 91精品国产91久久久久久蜜臀| 亚洲国产精品久久久久| 欧美亚洲国产精品久久蜜芽| 岛国搬运www久久| 亚洲精品无码久久毛片|