STL之deque

连续存储结构,即其每个元素在内存上也是连续的,类似于vector, 不同之处在于,deque提供了两级数组结构, 第一级完全类似于vector,代表实际容器;另一级维护容器的首位地址。
这样,deque除了具有vector的所有功能外,还支持高效的首/尾端插入/删除操作。
deque是在功能上合并了vector和list。
头文件:

#include<deque>

创建及初始化:

deque<int> c;	创建一个空的deque
deque<int> c1(c2);	复制deque,复制跟c1一模一样的队列c2
deque<int> c(n);	        创建一个deque,元素个数为n,且值均为0
deque<int> c(n,num);    	创建一个deque,元素个数为n,且值均为num
c.assign(n,num);	初始化deque, 初始化后元素个数为n,且值均为num
deque<int>::iterator it;	正向迭代器
deque<int>::reverse_iterator rit;   逆向迭代器

数据访问:

c.at(idx);	返回索引下标idx所指的数据(从0开始)
c.front();	返回第一个数据
c.back();	返回最后一个数据
c.begin();	返回指向第一个数据的迭代器
c.end();	返回指向最后一个数据的下一个位置的迭代器
c.rbegin();	返回逆向队列的第一个数据
c.rend();	返回指向逆向队列的最后一个数据的下一个位置的迭代器

插入及删除(pos、beg、end均为迭代器):

c.push_back(num);	在尾部加入一个数据num
c.push_front(num);	在头部插入一个数据num
c.insert(pos,num);	在该pos位置的数前面插入一个num
c.insert(pos,n,num);	在该pos位置的数前面插入n个num
c.insert(pos,beg,end);	在该pos位置的数前插入在[beg,end)区间的数据

c.pop_back();	删除最后一个数据
c.pop_front();	删除头部数据
c.erase(pos);	删除pos位置的数据
c.erase(beg,end);	删除[beg,end)区间的数据
其他操作
c.clear();	销毁所有数据,释放内存
c.empty();	判断容器是否为空
c.resize(n);	deque队列的长度置为n,只保留队列前n个数
c.size();	返回容器中实际数据的个数
swap(c1,c2);	将c1和c2元素互换

//在deque中查找某元素
deque<int>::iterator pos=find(c.begin(),c.end(),num);
if(pos!=c.end()) printf("find success\n");
else printf("find failed\n");
//反向遍历队列中的元素:
deque<int>::reverse_iterator rit;
for(rit = c.rbegin();rit != c.rend(); rit++)
        printf("%d ",*rit);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值