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


            參考代碼:
             1 /************************************************************************
             2 * deque:
             3 *    1, 分塊分配空間,非順序存儲,隨機(jī)訪問是通過復(fù)雜的iterator實(shí)現(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)航

            隨筆分類

            最新隨筆

            最新評論

            閱讀排行榜

            欧美精品丝袜久久久中文字幕| 久久免费的精品国产V∧| 欧美激情精品久久久久久久九九九 | 久久精品无码一区二区日韩AV| 婷婷久久五月天| 99国产精品久久久久久久成人热| 精品熟女少妇aⅴ免费久久| 青青青青久久精品国产h久久精品五福影院1421| 久久久无码精品午夜| 久久久精品人妻一区二区三区四| 国内精品久久久久久久coent| 久久久精品国产免大香伊| 国产一区二区三区久久| 久久99热这里只有精品66| 四虎国产精品免费久久久| 亚洲国产成人久久综合野外| 久久亚洲国产中v天仙www | 精品久久亚洲中文无码| 久久精品国产免费| 欧美噜噜久久久XXX| 国产精品久久久久免费a∨| 久久精品一区二区国产| 色综合久久久久综合体桃花网| 日日狠狠久久偷偷色综合96蜜桃| 精品免费tv久久久久久久| 色综合久久无码中文字幕| 狠狠色丁香久久婷婷综合| 色偷偷88欧美精品久久久| 99国内精品久久久久久久| 久久777国产线看观看精品| 久久国产热精品波多野结衣AV| 亚洲色欲久久久综合网| 一本色道久久88—综合亚洲精品| 国产精品久久久久久久app| 日本亚洲色大成网站WWW久久| 热RE99久久精品国产66热| 国产亚洲美女精品久久久| 久久有码中文字幕| 一本久道久久综合狠狠躁AV| 日韩美女18网站久久精品| 久久天天躁狠狠躁夜夜avapp|