青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Just enjoy programming

c++ STL 容器

參考:STL源碼分析

(一)vector容器
vector的數(shù)據(jù)安排以及操作方式,與array非常相似。兩者的唯一區(qū)別在于空間的運用的靈活性。array是靜態(tài)空間,一旦配置了就不能改變。vector是動態(tài)空間,隨著元素的加入,它的內(nèi)部機制會自行擴充空間以容納新元素。因此,vector的運用對于內(nèi)存的合理利用與運用的靈活性有很大的幫助,我們再也不必因為害怕空間不足而一開始要求一個大塊的array。

vector動態(tài)增加大小,并不是在原空間之后持續(xù)新空間(因為無法保證原空間之后尚有可供配置的空間),而是以原大小的兩倍另外配置一塊較大的空間,然后將原內(nèi)容拷貝過來,然后才開始在原內(nèi)容之后構(gòu)造新元素,并釋放原空間。因此,對vector的任何操作,一旦引起空間重新配置,指向原vector的所有迭代器就都失效了。

(二)list容器
相對于vector的連續(xù)空間,list就顯得復(fù)雜許多,它的好處是每次插入或刪除一個元素,就配置或釋放一個元素空間。因此,list對于空間的運用有絕對的精準,一點也不浪費。而且,對于任何位置的元素插入或元素移除,list永遠是常數(shù)時間。STL中的list是一個雙向鏈表,而且是一個環(huán)狀雙向鏈表。

(三)deque容器
 deque 是一種雙向開口的連續(xù)線性空間。所謂雙向開口,意思是可以在隊尾兩端分別做元素的插入和刪除操作。deque和vector的最大差異,一在于deque允許于常數(shù)時間內(nèi)對起頭端進行元素的插入或移除操作,二在于deque沒有所謂容量觀念,因為它是動態(tài)地以分段連續(xù)空間組合而成,隨時可以增加一段新的空間并鏈接在一起。換句話說,像vector那樣"因舊空間不足而重新配置一塊更大空間,然后復(fù)制元素,再釋放舊空間"這樣的事情在 deque是不會發(fā)生的。

deque是由一段一段的定量連續(xù)空間構(gòu)成。一旦有必要在deque的前端或尾端增加新空間,便配置一段定量連續(xù)空間,串接在整個deque的頭端或尾端。deque的最大任務(wù),便是在這些分段的定量連續(xù)空間上,維護其整體連續(xù)的假象,并提供隨機存取的接口。避開了"重新配置,復(fù)制,釋放"的輪回,代價則是復(fù)雜的迭代器架構(gòu)。因為有分段連續(xù)線性空間,就必須有中央控制,而為了維持整體連續(xù)的假象,數(shù)據(jù)結(jié)構(gòu)的設(shè)計及迭代器前進后退等操作都頗為繁瑣。

deque采用一塊所謂的map作為主控。這里的map是一小塊連續(xù)空間,其中每個元素都是指針,指向另一段連續(xù)線性空間,稱為緩沖區(qū)。緩沖區(qū)才是deque的存儲空間主體。SGI STL允許我們指定緩沖區(qū)大小,默認值0表示將使用512 bytes緩沖區(qū)。

(四)stack
stack 是一種先進后出(First In Last Out , FILO)的數(shù)據(jù)結(jié)構(gòu)。它只有一個出口,stack 允許新增元素,移除元素,取得最頂端元素。但除了最頂端外,沒有任何其它方法可以存取stack的其它元素,stack不允許遍歷行為。

以某種容器作為底部結(jié)構(gòu),將其接口改變,使之符合“先進后出”的特性,形成一個stack,是很容易做到的。deque是雙向開口的數(shù)據(jù)結(jié)構(gòu),若以deque為底部結(jié)構(gòu)并封閉其頭端開口,便輕而易舉地形成了一個stack.因此,SGI STL 便以deque作為缺省情況下的stack底部結(jié)構(gòu),由于stack 系以底部容器完成其所有工作,而具有這種"修改某物接口,形成另一種風(fēng)貌"之性質(zhì)者,稱為adapter(配接器),因此,STL stack 往往不被歸類為container(容器),而被歸類為 container adapter.

(五) queue
queue是一種先進先出(First In First Out,FIFO) 的數(shù)據(jù)結(jié)構(gòu)。它有兩個出口,queue允許新增元素,移除元素,從最底端加入元素,取得最頂端元素。但除了最底端可以加入,最頂端可以取出外,沒有任何其它方法可以存取queue的其它元素。

以某種容器作為底部結(jié)構(gòu),將其接口改變,使之符合“先進先出”的特性,形成一個queue,是很容易做到的。deque是雙向開口的數(shù)據(jù)結(jié)構(gòu),若以 deque為底部結(jié)構(gòu)并封閉其底部的出口和前端的入口,便輕而易舉地形成了一個queue.因此,SGI STL 便以deque作為缺省情況下的queue底部結(jié)構(gòu),由于queue 系以底部容器完成其所有工作,而具有這種"修改某物接口,形成另一種風(fēng)貌"之性質(zhì)者,稱為adapter(配接器),因此,STL queue往往不被歸類為container(容器),而被歸類為 container adapter.

(六)heap
heap并不歸屬于STL容器組件,它是個幕后英雄,扮演priority queue的助手。priority queue允許用戶以任何次序?qū)⑷魏卧赝迫肴萜髦校〕鰰r一定按從優(yōu)先權(quán)最高的元素開始取。按照元素的排列方式,heap可分為max-heap和min-heap兩種,前者每個節(jié)點的鍵值(key)都大于或等于其子節(jié)點鍵值,后者的每個節(jié)點鍵值(key)都小于或等于其子節(jié)點鍵值。因此, max-heap的最大值在根節(jié)點,并總是位于底層array或vector的起頭處;min-heap的最小值在根節(jié)點,亦總是位于底層array或vector起頭處。STL 供應(yīng)的是max-heap,用c++實現(xiàn)。
堆排序c語言實現(xiàn)
http://m.shnenglu.com/tankzhouqiang/archive/2011/03/21/142413.html

(七)priority_queue
priority_queue是一個擁有權(quán)值觀念的queue,它允許加入新元素,移除舊元素,審視元素值等功能。由于這是一個queue,所以只允許在底端加入元素,并從頂端取出元素,除此之外別無其它存取元素的途徑。priority_queue帶有權(quán)值觀念,其內(nèi)的元素并非依照被推入的次序排列,而是自動依照元素的權(quán)值排列(通常權(quán)值以實值表示)。權(quán)值最高者,排在最前面。缺省情況下priority_queue系利用一個max-heap完成,后者是一個以vector表現(xiàn)的 complete binary tree.max-heap可以滿足priority_queue所需要的"依權(quán)值高低自動遞減排序"的特性。
priority_queue完全以底部容器作為根據(jù),再加上heap處理規(guī)則,所以其實現(xiàn)非常簡單。缺省情況下是以vector為底部容器。queue以底部容器完成其所有工作。具有這種"修改某物接口,形成另一種風(fēng)貌"之性質(zhì)者,稱為adapter(配接器),因此,STL priority_queue往往不被歸類為container(容器),而被歸類為container adapter.

(八)set,multiset
set的特性是,所有元素都會根據(jù)元素的鍵值自動被排序。set的元素不像map那樣可以同時擁有實值(value)和鍵值(key), set 元素的鍵值就是實值,實值就是鍵值,set不允許兩個元素有相同的值。set是通過紅黑樹來實現(xiàn)的,由于紅黑樹(RB-tree)是一種平衡二叉搜索樹,自動排序的效果很不錯,所以標準的STL的set即以RB-Tree為底層機制。又由于set所開放的各種操作接口,RB-tree也都提供了,所以幾乎所有的set操作行為,都只有轉(zhuǎn)調(diào)用RB-tree的操作行為而已。

multiset的特性以及用法和set完全相同,唯一的差別在于它允許鍵值重復(fù),因此它的插入操作采用的是底層機制RB-tree的insert_equal()而非insert_unique().

(九)map,multimap
map的特性是,所有元素都會根據(jù)元素的鍵值自動被排序。map的所有元素都是pair,同時擁有實值(value)和鍵值(key).  pair的第一元素被視為鍵值,第二元素被視為實值。map不允許兩個元素擁有相同的鍵值.由于RB-tree是一種平衡二叉搜索樹,自動排序的效果很不錯,所以標準的STL map即以RB-tree為底層機制。又由于map所開放的各種操作接口,RB-tree也都提供了,所以幾乎所有的map操作行為,都只是轉(zhuǎn)調(diào)RB-tree的操作行為。
multimap的特性以及用法與map完全相同,唯一的差別在于它允許鍵值重復(fù),因此它的插入操作采用的是底層機制RB-tree的insert_equal()而非insert_unique。

posted on 2011-06-02 11:28 周強 閱讀(5838) 評論(1)  編輯 收藏 引用 所屬分類: c++ STL源碼分析

評論

# re: c++ STL 容器[未登錄] 2013-08-28 10:43 柳晴

如果要priority_queue不含重復(fù)元素,怎么寫?  回復(fù)  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久女同互慰一区二区三区| 欧美二区在线播放| 麻豆九一精品爱看视频在线观看免费| 国内免费精品永久在线视频| 久久国产精品久久精品国产| 免费久久99精品国产自| 国产婷婷97碰碰久久人人蜜臀| 久久精品中文字幕免费mv| 久久久人成影片一区二区三区观看 | 欧美喷水视频| 欧美大片在线观看一区| 欧美国内亚洲| 国产精品久久久久久久9999| 欧美亚洲第一区| 国产亚洲午夜| 亚洲激情成人网| 一区二区三区三区在线| 亚洲在线免费观看| 久久久久久久综合日本| 欧美va亚洲va日韩∨a综合色| 亚洲黑丝在线| 亚洲欧美一区二区激情| 亚洲男人的天堂在线观看| 久久久精品一区二区三区| 国内外成人在线视频| 韩国一区二区三区美女美女秀| 亚洲视频在线观看网站| 一区二区三区国产在线| 国产精品一区二区三区成人| 欧美成人亚洲成人| 亚洲天堂久久| 一本久久a久久免费精品不卡| 亚洲福利视频在线| 亚洲激情亚洲| 亚洲综合清纯丝袜自拍| 欧美一区二区三区四区视频| 久久久91精品国产一区二区精品| 久久免费99精品久久久久久| 欧美精品日日鲁夜夜添| 国产精品一区二区三区成人| 日韩一级黄色片| 久久综合综合久久综合| 久久精品国产99| 亚洲国产第一页| 欧美大胆人体视频| 免费黄网站欧美| 一本久久综合亚洲鲁鲁五月天| 免费久久99精品国产自在现线| 欧美在线播放视频| 亚洲国产精品久久精品怡红院| 亚洲一区二区在线看| 毛片基地黄久久久久久天堂| 亚洲一区二区三区免费观看| 欧美二区乱c少妇| 国产美女精品免费电影| 99ri日韩精品视频| 亚洲国产福利在线| 久久久免费av| 韩国av一区二区三区| 欧美承认网站| 亚洲伦理在线观看| 欧美h视频在线| 你懂的亚洲视频| 香蕉久久一区二区不卡无毒影院| 亚洲一区二区三区乱码aⅴ| 国内外成人免费激情在线视频网站| 免费h精品视频在线播放| 欧美美女操人视频| 久久国产精品亚洲77777| 久久精品中文字幕一区二区三区 | 久久一区二区三区超碰国产精品| 国产精品一区二区你懂得| 欧美影院成年免费版| 日韩视频一区二区三区在线播放免费观看 | 欧美成人免费在线视频| 欧美日韩精品在线视频| 亚洲一卡久久| 久久精品国产亚洲精品| 欧美高清视频在线播放| 欧美一区二区三区视频在线| 美女黄色成人网| 久久精品一二三区| 欧美精品九九| 国产综合久久久久影院| 中文国产成人精品| 亚洲国产精品成人综合色在线婷婷 | 久久综合九色| 亚洲第一福利视频| 久久综合一区二区| 日韩视频精品在线| 中文在线资源观看网站视频免费不卡| 亚洲欧美www| 日韩一级精品| 欧美成人中文| 99国内精品久久| 日韩午夜精品| 欧美巨乳在线观看| 亚洲国产成人不卡| 亚洲成人在线免费| 欧美在线精品免播放器视频| 亚洲男人的天堂在线观看| 欧美人成免费网站| 亚洲性夜色噜噜噜7777| 欧美有码在线观看视频| 一区视频在线播放| 欧美极品欧美精品欧美视频| 在线亚洲伦理| 欧美激情四色| 小黄鸭精品密入口导航| 亚洲人体偷拍| 1024精品一区二区三区| 国产专区精品视频| 国产精品福利网| 欧美视频官网| 亚洲另类在线视频| 久久亚洲私人国产精品va| 1024欧美极品| 国产亚洲精品久久久久动| 欧美日韩久久精品| 久久久女女女女999久久| 亚洲精品黄网在线观看| 国产精品一区二区欧美| 欧美日韩精品在线观看| 老司机免费视频一区二区| 欧美一区在线直播| 欧美一区二区三区另类 | 午夜精品视频一区| 亚洲中字黄色| 午夜精品美女久久久久av福利| 亚洲国产成人91精品| 久久亚洲捆绑美女| 亚洲欧美日本在线| 亚洲综合视频1区| 久久裸体视频| aa级大片欧美三级| 麻豆亚洲精品| 国产精品99久久久久久久久| 免费观看成人www动漫视频| 久久久久久久久久久久久久一区| 亚洲一区国产| 午夜精品久久| 久久www成人_看片免费不卡| 久久精视频免费在线久久完整在线看| 亚洲自拍16p| 欧美一区二区三区久久精品| 亚洲免费在线视频| 麻豆91精品91久久久的内涵| 亚洲电影第1页| 亚洲一区亚洲| 久久综合99re88久久爱| 欧美福利在线| 国产午夜精品在线观看| 亚洲午夜高清视频| 欧美国产精品人人做人人爱| 一区二区三区视频在线看| 欧美粗暴jizz性欧美20| 亚洲成人中文| 亚洲麻豆av| 国产日韩在线不卡| 最新中文字幕亚洲| 国产精品久久久久久久久免费桃花 | 在线欧美电影| 欧美高清视频在线观看| 先锋影音久久久| 欧美四级在线| 中文在线不卡视频| 蜜臀久久久99精品久久久久久 | 欧美一区二区免费观在线| 国产区日韩欧美| 欧美jizzhd精品欧美巨大免费| 欧美大片网址| 国内精品**久久毛片app| 一区二区三区不卡视频在线观看| 欧美二区乱c少妇| 久久精品国产精品亚洲| 一色屋精品视频免费看| 久久婷婷人人澡人人喊人人爽| 日韩一级在线观看| 欧美日韩福利| 欧美一区二区三区四区高清| 午夜精品在线观看| 亚洲人成人一区二区在线观看| 免费国产一区二区| 欧美日韩免费观看一区=区三区| 日韩视频―中文字幕| 久久综合导航| 欧美午夜精彩| 狂野欧美激情性xxxx欧美| 国产一区二区福利| 欧美国产日本高清在线| 欧美日韩色一区| 亚洲精品影院在线观看| 国产欧美精品在线播放| 欧美国产日韩亚洲一区| 亚洲激情二区| 麻豆国产精品va在线观看不卡| av成人动漫| 久久成人精品无人区| 一区二区三区欧美在线| 香港成人在线视频|