老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

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

一、簡介

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

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

二、完整程序代碼

/*請務必運行以下程序后對照閱讀*/ 
 
#include  
#include  
#include  
#include  
using namespace std; 
 
void print(int num) 
{ 
  cout << num << " "; 
} 
 
int main() 
{ 
  //1. 初始化 
  deque v; 
  deque::iterator iv; 
 
  v.assign(10, 2);//將10個值為2的元素賦到deque中 
  cout << v.size() << endl; //返回deque實際含有的元素數量 
  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  
  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; 
 
  //危險的做法,但一般我們就像訪問數組那樣操作就行 
  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  
  { 
    cout << "out_of_range at " << i << endl; 
  } 
  cout << endl; 
 
  //6. 清空 
  v.clear(); 
  cout << v.size() << endl;//0 
  for_each(v.begin(), v.end(), print); //已經clear,v.begin()==v.end(),不會有任何結果。 
 
  return 0; 
} 

三、補充

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

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

特點:

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

參考網址:http://www.cplusplus.com/reference/deque/deque/

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創新互聯。


文章名稱:C++STL入門教程(3)deque雙向隊列使用方法
文章轉載:http://www.xueling.net.cn/article/pdeiee.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 国产一区二区三区在线2021 | 国产超碰人人爽人人做人人添 | 久久不见久久见免费影院视频观看 | 嫩草导航 | 国产精品久久久久乳精毛片毛斤 | 欧美高清69| 精品精品国产三级a∨在线 麻豆传媒免费视频 | 国产男女视频在线 | 国产真实乱免费高清视频 | 在线亚洲网站 | 欧美大逼视频 | 色综合久久综合中文综合网 | 97人人爽人人爽人人一区二区 | 欧美日韩黄色大片 | 性xxxx搡xxxxx搡欧美 | 99欧美日本一区二区留学生 | 亚洲sss视频在线视频 | JIZZJIZZ亚洲日本少妇 | 精品久久久久久无码专区 | 日本少妇高潮喷水视频 | 四虎最新网址 | 国产宾馆自拍 | 午夜激情一区二区 | 97久久人人爽人人爽人人片 | 97porm国内自拍视频 | 国产区精品在线观看 | 日韩一区免费视频 | 欧美亚洲另类久久综合二区 | 久久综合九色综合网站 | 久久天天 | 久久夜色精品国产噜噜 | 日本激情视频图片小说 | 国产高清亚洲精品视bt天堂频 | 亚洲国产欧美日韩欧美特级 | 三级毛片视频 | 免费看一级黄色片 | 人妻被粗大猛进猛出国产 | 日本不卡在线一区二区三区视频 | 亚洲精品久久激情国产片 | 成人国产精品色哟哟 | gav成人免费播放器 男人操女人视频在线观看 日本在线免费 |