deque.clear();

//移除容器的所有数据

 1 #include <iostream>
2 #include <deque>
3
4 using namespace std;
5
6 int main()
7 {
8 int num[] = { 111,222,333,444,555 };
9 deque<int> deqInt_A(num, num + size(num));
10
11 cout << "deqInt_A中的元素个数为:";
12 cout << deqInt_A.size() << endl;
13
14 cout << "deqInt_A所占用内存:";
15 cout << sizeof(deqInt_A) << endl;
16
17 cout << "遍历deqInt_A:";
18 for (deque<int>::iterator it = deqInt_A.begin(); it != deqInt_A.end(); it++)
19 {
20 cout << *it << " ";
21 }
22
23 //删除容器中
24 deqInt_A.clear();
25
26 cout << "\n\nclear后,deqInt_A中的元素个数为:";
27 cout << deqInt_A.size();
28 cout << "\ndeqInt_A所占用内存:";
29 cout << sizeof(deqInt_A);
30 cout << "\nclear后,遍历deqInt_A:" << endl;
31 for (deque<int>::iterator it = deqInt_A.begin(); it != deqInt_A.end(); it++)
32 {
33 cout << *it << " ";
34 }
35
36 return 0;
37 }

打印结果:

可以发现内存是并没有释放的

deque.erase(beg,end);

//删除[beg,end)区间的数据,返回下一个数据的位置。

 1 #include <iostream>
2 #include <deque>
3
4 using namespace std;
5
6 int main()
7 {
8 int num[] = { 111,222,333,444,555 };
9 deque<int> deqInt_A(num, num + size(num));
10
11 cout << "遍历deqInt_A:";
12 for (deque<int>::iterator it = deqInt_A.begin(); it != deqInt_A.end(); it++)
13 {
14 cout << *it << " ";
15 }
16 cout << "\ndeqInt_A中的元素个数为:";
17 cout << deqInt_A.size() << endl;
18
19 cout << "deqInt_A所占用内存:";
20 cout << sizeof(deqInt_A) << endl;
21
22
23
24 cout << "\n删除容器中前三个元素后,遍历deqInt_A:";
25 //删除容器中前三个元素后,用返回的迭代器遍历,返回了下一个元素的位置
26 for (deque<int>::iterator it = deqInt_A.erase(deqInt_A.begin(), deqInt_A.begin() +3); it != deqInt_A.end(); it++)
27 {
28 cout << *it << " ";
29 }
30 cout << "\n删除容器中前三个元素后,deqInt_A中的元素个数为:";
31 cout << deqInt_A.size();
32
33 cout << "\n删除容器中前三个元素后,deqInt_A所占用内存:";
34 cout << sizeof(deqInt_A);
35
36 return 0;
37 }

打印结果:

可以发现,deqInt_A中的元素删除后,占用的内存空间大小并没有变化

deque.erase(pos);

//删除pos位置的数据,返回下一个数据的位置。

 1 #include <iostream>
2 #include <deque>
3
4 using namespace std;
5
6 int main()
7 {
8 int num[] = { 111,222,333,444,555 };
9 deque<int> deqInt_A(num, num + size(num));
10
11 cout << "遍历deqInt_A:";
12 for (deque<int>::iterator it = deqInt_A.begin(); it != deqInt_A.end(); it++)
13 {
14 cout << *it << " ";
15 }
16 cout << "\ndeqInt_A中的元素个数为:";
17 cout << deqInt_A.size() << endl;
18
19 cout << "deqInt_A所占用内存:";
20 cout << sizeof(deqInt_A) << endl;
21
22 cout << "\n删除容器中第三个元素后边的元素后,用返回的迭代器遍历后边的元素:";
23 //删除容器中第三个元素后边的元素后,用返回的迭代器遍历,返回了下一个元素的位置,注意这个数字不是第三个,是第三个之后的那个元素
24 for (deque<int>::iterator it = deqInt_A.erase(deqInt_A.begin() + 3); it != deqInt_A.end(); it++)
25 {
26 cout << *it << " ";
27 }
28 cout << "\n遍历 deqInt_A 中所有的元素:";
29 for (deque<int>::iterator it = deqInt_A.begin(); it != deqInt_A.end(); it++)
30 {
31 cout << *it << " ";
32 }
33 cout << "\n删除容器中第三个元素后边的元素后,deqInt_A中的元素个数为:";
34 cout << deqInt_A.size();
35
36 cout << "\n删除容器中第三个元素后边的元素后,deqInt_A所占用内存:";
37 cout << sizeof(deqInt_A);
38
39 return 0;
40 }

打印结果:

一般在项目中删除单个元素会这样用:

 1 #include <iostream>
2 #include <deque>
3
4 using namespace std;
5
6 int main()
7 {
8 int num[] = { 111,222,333,444,555 };
9 deque<int> deqInt_A(num, num + size(num));
10
11 //删除等于 444 的元素
12 for (deque<int>::iterator it = deqInt_A.begin(); it != deqInt_A.end();)
13 {
14 if (*it == 444)
15 {
16 it = deqInt_A.erase(it); //删除元素后,erase 会返回下一个元素的位置,相当于 it++操作了
17 }
18 cout << *it << " ";
19 it++; //不把it++ 写到for循环的条件语句中,是为了避免删除元素后的越界访问,比如删除 444 后,555会在444的位置,这时候it++就会越界
20 }
21
22 return 0;
23 }

打印结果:

=======================================================================================================================

STL——容器(deque)deque 的删除 clear() erase()的更多相关文章

  1. STL——容器(deque) 构造 & 头尾添加删除元素

    1.deque容器概念 deque是"double-ended queue"的缩写,和vector一样都是STL的容器,唯一不同的是:deque是双端数组,而vector是单端的. ...

  2. STL容器:deque双端队列学习

    所谓deque,是"double-ended queue"的缩写; 它是一种动态数组形式,可以向两端发展,在尾部和头部插入元素非常迅速; 在中间插入元素比较费时,因为需要移动其它元 ...

  3. STL容器分析--deque

    deque,故名思义,双向队列.可以在头尾进行插入删除. 而STL中采用了链表+线性表的数据结构来实现deque,因而除了满足双向队列的特点以外,还支持随机访问. 下面,贴一段代码. 总览:双向队列是 ...

  4. STL——容器(deque) deque 的大小

    1. deque 的大小 deque.size();              //返回容器中元素的个数 1 #include <iostream> 2 #include <dequ ...

  5. STL——容器(deque) 元素的存取&迭代器

    1. deque 的数据存取 这个部分和 vector 几乎一样 第一  使用下标操作 dequeName[0] = 100; //小心越界 第二  使用at 方法 如: dequeName.at(2 ...

  6. STL——容器(deque)deque 的插入 insert()

    deque.insert(pos,elem); //在pos位置插入一个elem元素的拷贝,返回新数据的位置. 1 #include <iostream> 2 #include <d ...

  7. STL——容器(deque) deque 的赋值 assign() operator=() swap()

    deque 的赋值分下边4种方法: deque.assign(beg,end); //将[beg, end)区间中的数据拷贝赋值给本身.注意该区间是左闭右开的区间. 1 #include <io ...

  8. ACM常用STL容器

    // STL(标准模板库),由三大部分组成:容器,算法,迭代器 // STL六大组件:container(容器),algorthm(算法),iterator(迭代器) // function obje ...

  9. C++中防止STL中迭代器失效——map/set等关联容器——vector/list/deque等序列容器—如何防止迭代器失效—即erase()的使用

    序列性容器::(vector和list和deque)   erase迭代器不仅使所有指向被删元素的迭代器失效,而且使被   删元素之后的所有迭代器失效,所以不能使用erase(iter++)的方 式, ...

随机推荐

  1. 'sortbitwise'是什么意思

    问题 flag sortbitwise 在ceph中是什么意思,在Jewel版本下可以看到多了这个flags [root@lab8106 current]# ceph -s cluster ffe7a ...

  2. ceph客户端服务端属性匹配关系

    ceph的server是定期会发布版本,而它的客户端是放到linux 内核当中的,一些属性的支持是依赖于内核版本的,这样就存在一些问题,一些功能后端支持,而客户端旧了:还有可能是客户端用的很新的内核, ...

  3. ubuntu13.04修改默认启动内核

    ubuntu下面的启动内核选项跟其他操作系统不一样,有个子菜单,比如我在默认的ubuntu13.04上安装了一个新的内核3.14.5,那么默认的第一项是3.14.5内核,第二项是一个子菜单,第二项里面 ...

  4. threading中的其他部分方法

    import threading def wahaha(n): print(n, threading.current_thread()) # 1 <Thread(Thread-1, starte ...

  5. 使用create-react-app 搭建react + ts + antd框架

    一.创建项目 使用npx create-react-app (项目名) --template typescript 创建项目 ①如果App.tsx文件有如下报错: (没有报错的请忽略) 需要将tsco ...

  6. wireshark实战应用(长期更新,工作随笔)

    Wireshark检索语法 过滤IP地址 ip.addr eq 192.168.1.1 ip.addr == 192.168.1.1 //过滤源IP地址 ip.src eq 192.168.1.1 i ...

  7. 玩转百度地图API(地图,坐标,标记,添加控件,2D图,混合图,智能搜索,地址解析器,信息窗口)

    1.注册得到appkey 2.直接上代码 <!DOCTYPE html> <html> <head> <meta http-equiv="Conte ...

  8. MongoDB动态建表方案(官方原生驱动)

    MongoDB动态建表方案(官方原生驱动) 需求前提:表名动态,表结构静态,库固定 1.导入相关依赖 <dependency> <groupId>org.mongodb< ...

  9. level2行情是什么意思?

    level2行情是由上海证券交易所推出的实时行情信息收费服务产品,主要提供在上海证券交易所上市交易的证券产品的实时交易数据,包括十档行情,买卖队列,逐笔成交,委托总量和加权价格等数据. 投资者根据其功 ...

  10. 如何使用Camtasia进行电脑录制屏幕

    在现在的网络互联网时代,越来越多的人走上了自媒体的道路.有些自媒体人会自己在网络上录制精彩视频,也有一些人会将精彩.热门的电影剪辑出来再加上自己给它的配音,做成大家喜欢看的电影剪辑片段.相信不管大家是 ...