deque双向队列是一种双向开口的连续线性空间,可以高效的在头尾两端插入和删除元素,deque在接口上和vector非常相似,下面列出deque的常用成员函数:

 

deque的实现比较复杂,内部会维护一个map(注意!不是STL中的map容器)即一小块连续的空间,该空间中每个元素都是指针,指向另一段(较大的)区域,这个区域称为缓冲区,缓冲区用来保存deque中的数据。因此deque在随机访问和遍历数据会比vector慢。具体的deque实现可以参考《STL源码剖析》,当然此书中使用的SGI STL与VS2008所使用的PJ STL的实现方法还是有区别的。下面给出了deque的结构图:

由于篇幅问题,deque的实现细节就不再深入了,下面给出deque的使用范例:

  1. //双向队列 deque
  2. //by MoreWindows http://blog.csdn.net/morewindows
  3. #include <deque>
  4. #include <cstdio>
  5. #include <algorithm>
  6. using namespace std;
  7. int main()
  8. {
  9. deque<int> ideq(20); //Create a deque ideq with 20 elements of default value 0
  10. deque<int>::iterator pos;
  11. int i;
  12. //使用assign()赋值  assign在计算机中就是赋值的意思
  13. for (i = 0; i < 20; ++i)
  14. ideq[i] = i;
  15. //输出deque
  16. printf("输出deque中数据:\n");
  17. for (i = 0; i < 20; ++i)
  18. printf("%d ", ideq[i]);
  19. putchar('\n');
  20. //在头尾加入新数据
  21. printf("\n在头尾加入新数据...\n");
  22. ideq.push_back(100);
  23. ideq.push_front(i);
  24. //输出deque
  25. printf("\n输出deque中数据:\n");
  26. for (pos = ideq.begin(); pos != ideq.end(); pos++)
  27. printf("%d ", *pos);
  28. putchar('\n');
  29. //查找
  30. const int FINDNUMBER = 19;
  31. printf("\n查找%d\n", FINDNUMBER);
  32. pos = find(ideq.begin(), ideq.end(), FINDNUMBER);
  33. if (pos != ideq.end())
  34. printf("find %d success\n", *pos);
  35. else
  36. printf("find failed\n");
  37. //在头尾删除数据
  38. printf("\n在头尾删除数据...\n");
  39. ideq.pop_back();
  40. ideq.pop_front();
  41. //输出deque
  42. printf("\n输出deque中数据:\n");
  43. for (pos = ideq.begin(); pos != ideq.end(); pos++)
  44. printf("%d ", *pos);
  45. putchar('\n');
  46. return 0;
  47. }

运行结果如下:

另外要注意一点。对于deque和vector来说,尽量少用erase(pos)和erase(beg,end)。因为这在中间删除数据后会导致后面的数据向前移动,从而使效率低下。

转载请标明出处,原文地址:http://blog.csdn.net/morewindows/article/details/6946811

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<vector>
#include<queue>
using namespace std;
const int INF=0x3f3f3f3f;
#define mem(x,y) memset(x,y,sizeof(x))
#define SI(x) scanf("%d",&x)
#define PI(x) printf("%d",x)
#define SD(x) scanf("%lf",&x)
#define P_ printf(" ")
typedef long long LL;
const int MAXN=;
int m[MAXN],a[MAXN];
int main(){
deque<int>q();
deque<int>::iterator iter;
for(int i=;i<;i++)q[i]=i;
q.push_front();
q.push_back();
for(iter=q.begin();iter!=q.end();iter++)printf("%d ",*iter);puts("");
q.pop_front();q.pop_back();
iter=q.end();iter--;
printf("%d %d\n",*q.begin(),*iter);
return ;
}
 
 

最新文章

  1. Web服务器具体开发流程
  2. RDIFramework.NET ━ 9.4 角色管理 ━ Web部分
  3. Extjs给gridPanel添加单价双击事件和获取当前行的数据
  4. 【sublime】解决汉字输入的办法——InputHelper;在sublime中输入汉字==》InputHelper方法
  5. c# 6.0 学习笔记
  6. hdu 4635 Strongly connected 强连通
  7. CSDN-markdown语法之怎样使用LaTeX语法编写数学公式
  8. C#中对属性和字段的理解
  9. 前端开发面试题总结之——JAVASCRIPT(二)
  10. ES2018正则表达式更新
  11. WCF使用Net.tcp绑定时候出现错误:元数据包含无法解析的引用
  12. 求幂pow()
  13. spring框架的概述与入门
  14. [label][JavaScript] 自动填充内容的JavaScript 库
  15. java多态-向上转型和向下转型
  16. js--在页面元素上(移动到或获取焦点)、鼠标离开(或失去焦点)
  17. android 如何获取当前的Activity类名
  18. 单源最短路——dijkstra算法
  19. HDU3231拓扑排序
  20. 第十六章:自定义push notification sound

热门文章

  1. PBM文件格式
  2. 00UILabel控件的详解
  3. Mono For Android中简单实现按钮的动画效果
  4. C++临时对象销毁时间
  5. java代码收藏:获取HttpServletRequest中某一前缀的参数
  6. 《C语言深度剖析》学习笔记----C语言中的符号
  7. The MySQL C API 编程实例
  8. C#中log4net使用方法(一)
  9. C#中T的用法
  10. html系列教程--link mark meta