欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

C++STL入門教程(3)deque雙向隊列使用方法

一、簡介

讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:國際域名空間、網(wǎng)頁空間、營銷軟件、網(wǎng)站建設、陵川網(wǎng)站維護、網(wǎng)站推廣。

deque(Double Ended Queues,雙向隊列)和向量很相似,但是它允許在容器頭部快速插入和刪除(就像在尾部一樣)。

二、完整程序代碼

/*請務必運行以下程序后對照閱讀*/ 
 
#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個值為2的元素賦到deque中 
  cout << v.size() << endl; //返回deque實際含有的元素數(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);//在逆序迭代器上做++運算將指向容器中的前一個元素 
  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個元素而不是4個 
  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; 
 
  //危險的做法,但一般我們就像訪問數(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(),不會有任何結(jié)果。 
 
  return 0; 
} 

三、補充

實際上,deque是對vector和list優(yōu)缺點的結(jié)合,它是處于兩者之間的,一種優(yōu)化了的對序列兩端元素進行添加和刪除操作的基本序列容器。

它允許較為快速地隨機訪問,但它不像vector把所有的對象保存在一塊連續(xù)的內(nèi)存塊,而是采用多個連續(xù)的存儲塊,并且在一個映射結(jié)構中保存對這些塊及其順序的跟蹤。向deque兩端添加或刪除元素的開銷很小。它不需要重新分配空間,所以向末端增加元素比vector更有效。 

特點:

(1)  隨機訪問方便,即支持[ ] 操作符和vector.at(),但性能沒有vector好;
(2)  可以在內(nèi)部進行插入和刪除操作,但性能不及l(fā)ist;
(3)  可以在兩端進行入列出列操作;
(4)  相對于verctor占用更多的內(nèi)存。

參考網(wǎng)址:http://www.cplusplus.com/reference/deque/deque/

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

分享題目:C++STL入門教程(3)deque雙向隊列使用方法
地址分享:http://aaarwkj.com/article44/pdeiee.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設、企業(yè)建站、移動網(wǎng)站建設網(wǎng)站制作、軟件開發(fā)電子商務

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設公司
丁香色婷婷国产精品视频| 秒播视频午夜福利在线观看| 午夜少妇伦理一区二区| 婷婷亚洲五月伊人91| 青青草免费在线播放视频网站| 激情内射日本一区二区三区| 色婷婷丝袜一区网站| 91蜜臀视频在线播放| 和富婆啪啪一区二区免费看| 欧美国产一级二级三级| 91麻豆粉色视频在线| 午夜视频免费在线观看| 日韩中文字幕在线首页| 色呦呦视频在线免费看| 国产亚洲精品一区久久| 欧美日韩在线精品1区2区| 久久99国产精品成人免费| 日韩精品熟妻人女亚洲一区| 日韩欧美中文字幕一区二区| 欧美黄片网站在线观看| 日韩av一区二区人妻| 亚洲精品成人久久国产| 久久综合婷婷亚洲五月| 97超频在线观看免费| 国产精品日韩经典中文字幕| 欧美一日韩一级片免费看| 久久久人妻精品一区二区三区四区| 大胆丰满邻居少妇在线观看 | 韩国av电影免费观看| 欧美日韩国内在线视频| 尤物在线免费观看视频| 国产不卡视频观看网站| 欧美日韩黄色人人小视频| 日本一区二区三区中文字幕不卡| 国产精品国产三级国产av一区| 日本熟妇中文字幕系列| 男人天堂av一区二区| 久草视频免费福利资源站| 国产欧美日韩国产精品| 一区二区三区视频在线国产| 成年人午夜在线观看网址|