一、簡介
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長期合作伙伴,公司提供的服務(wù)項(xiàng)目有:國際域名空間、網(wǎng)頁空間、營銷軟件、網(wǎng)站建設(shè)、陵川網(wǎng)站維護(hù)、網(wǎng)站推廣。
deque(Double Ended Queues,雙向隊(duì)列)和向量很相似,但是它允許在容器頭部快速插入和刪除(就像在尾部一樣)。
二、完整程序代碼
/*請(qǐng)務(wù)必運(yùn)行以下程序后對(duì)照閱讀*/ #include <deque> #include <iostream> #include <algorithm> #include <stdexcept> using namespace std; void print(int num) { cout << num << " "; } int main() { //1. 初始化 deque<int> v; deque<int>::iterator iv; v.assign(10, 2);//將10個(gè)值為2的元素賦到deque中 cout << v.size() << endl; //返回deque實(shí)際含有的元素?cái)?shù)量 cout << endl; //2. 添加 v.push_front(666); for (int i = 0; i < 10; i++) v.push_back(i); for_each(v.begin(), v.end(), print);//需要#include <algorithm> cout << endl; cout << v.size() << endl; cout << endl; //3. 插入及遍歷、逆遍歷 v.insert(v.begin() + 3, 99); v.insert(v.end() - 3, 99); for_each(v.begin(), v.end(), print); cout << endl; for_each(v.rbegin(), v.rend(), print);//在逆序迭代器上做++運(yùn)算將指向容器中的前一個(gè)元素 cout << endl; //一般遍歷寫法 for(iv = v.begin(); iv != v.end(); ++iv) cout << *iv << " "; cout << endl; cout << endl; //4. 刪除 v.erase(v.begin() + 3); for_each(v.begin(), v.end(), print); cout << endl; v.insert(v.begin() + 3, 99);//還原 v.erase(v.begin(), v.begin() + 3); //注意刪除了3個(gè)元素而不是4個(gè) for_each(v.begin(), v.end(), print); cout << endl; v.pop_front(); v.pop_back(); for_each(v.begin(), v.end(), print); cout << endl; cout << endl; //5. 查詢 cout << v.front() << endl; cout << v.back() << endl; //危險(xiǎn)的做法,但一般我們就像訪問數(shù)組那樣操作就行 for (int i = 15; i < 25; i++) cout << "Element " << i << " is " << v[i] << endl; //安全的做法 int i; try { for (i = 15; i < 25; i++) cout << "Element " << i << " is " << v.at(i) << endl; } catch (out_of_range err)//#include <stdexcept> { cout << "out_of_range at " << i << endl; } cout << endl; //6. 清空 v.clear(); cout << v.size() << endl;//0 for_each(v.begin(), v.end(), print); //已經(jīng)clear,v.begin()==v.end(),不會(huì)有任何結(jié)果。 return 0; }
三、補(bǔ)充
實(shí)際上,deque是對(duì)vector和list優(yōu)缺點(diǎn)的結(jié)合,它是處于兩者之間的,一種優(yōu)化了的對(duì)序列兩端元素進(jìn)行添加和刪除操作的基本序列容器。
它允許較為快速地隨機(jī)訪問,但它不像vector把所有的對(duì)象保存在一塊連續(xù)的內(nèi)存塊,而是采用多個(gè)連續(xù)的存儲(chǔ)塊,并且在一個(gè)映射結(jié)構(gòu)中保存對(duì)這些塊及其順序的跟蹤。向deque兩端添加或刪除元素的開銷很小。它不需要重新分配空間,所以向末端增加元素比vector更有效。
特點(diǎn):
(1) 隨機(jī)訪問方便,即支持[ ] 操作符和vector.at(),但性能沒有vector好;
(2) 可以在內(nèi)部進(jìn)行插入和刪除操作,但性能不及l(fā)ist;
(3) 可以在兩端進(jìn)行入列出列操作;
(4) 相對(duì)于verctor占用更多的內(nèi)存。
參考網(wǎng)址:http://www.cplusplus.com/reference/deque/deque/
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
分享題目:C++STL入門教程(3)deque雙向隊(duì)列使用方法
地址分享:http://vcdvsql.cn/article44/pdeiee.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、企業(yè)建站、移動(dòng)網(wǎng)站建設(shè)、網(wǎng)站制作、軟件開發(fā)、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)