STL序列容器之deque
一,deque的基础知识
1.deque的基础
- deque是“double-ended-queue”的缩写,意思是双端队列,其和vector的区别在于vector是单端的。
- deque在头部和尾部插入和删除元素非常快,但是在中部插入和删除元素比较耗时。
- deque支持随机存取元素(即通过数组下标可以直接访问和修改元素),其底层数据结构是数组。
- deque的操作和vector很相似,在许多操作上可以直接替换。
- 在使用deque之前需要导入头文件# include<deque>
二,deque的构造函数
1.无参构造函数
/* 无参构造函数 */
deque<int> d1;
2.带参数的构造函数
/* 带参构造函数一:用10个字符'A'初始化容器 */
deque<char> d1(,'A');
/* 用容器d1的前五个元素来初始化容器d2 */
deque<char> d2(d1.begin(),d1.begin()+);
3.拷贝构造函数
/* 定义含有是个字符'A'的容器 */
deque<char> d1(,'A');
/* 用上面的容器初始化下面的容器 */
deque<char> d2 = d1;
4.析构函数
deque的析构函数用来释放容器中元素所占用的内存。
三,deque的操作符重载
1.赋值操作符重载
// 定义双端队列d1
deque<int> d1(, );
// 定义双端队列d2
deque<int> d2;
// 使用赋值操作
d2 = d1;
2.数组下标操作符重载
// 定义双端队列d
deque<int> d(, );
// 数组下标操作,获取容器第二个元素
int i2 = d[];
cout << "i2 = " << i2 << endl;
// 数组下标操作,修改容器的第三个元素
d2[] = ;
cout << "i3 = " << d[] << endl;
四,deque的成员函数
1.在头部插入和移除元素
// 定义容器
deque<char> d1;
// 头部插入元素
d1.push_front('C');
d1.push_front('B');
d1.push_front('A');
// 头部元素删除
d1.pop_front();
2.在尾部插入和移除元素
// 定义容器
deque<char> d2;
// 尾部插入元素
d2.push_back('X');
d2.push_back('Y');
d2.push_back('Z');
// 删除尾部元素
d2.pop_back();
3.获取头部和尾部元素
// 定义容器
deque<char> d1(,'A');
// 获取首元素
char first = d1.front();
// 获取尾元素
char last = d1.back();
4.获取容器的长度
// 定义容器
deque<char> d1(,'A');
// 获取容器长度
int size = d1.size();
5.清空容器的元素
// 定义容器
deque<char> d1(,'A');
// 清空元素
d1.clear();
6.判断元素是否为空
// 定义容器
deque<char> d1(,'A');
// 判断元素是否为空
bool isEmpty = d1.empty();
7.重置容器长度
// 定义容器
deque<char> d(,'A');
// 重置容器元素为10个,不足的位置用字符'B'替代
d.resize(,'B');
// 重置容器元素为5个,多余的元素删除
d.resize();
8.获取和修改容器元素
// 定义容器
deque<char> d(,'A');
// 获取第3个元素
char c3 = d.at();
// 修改第三个元素
d.at() = 'B';
9.容器插入元素
// 定义容器d1
deque<char> d1(,'A');
// 定义容器d2
deque<char> d2(, 'B');
// 在容器d2的第二个位置插入字符'X'
d2.insert(d2.begin() + , 'X');
// 在容器d2的第四个位置插入5个字符'Z'
d2.insert(d2.begin() + , , 'Z');
// 在容器d2的最后插入容器d1
d2.insert(d2.end(), d1.begin(), d1.end());
10.容器删除元素
// 定义容器d1
deque<char> d1(,'A');
// 删除第2个元素
d1.erase(d1.begin() + );
// 删除第2个到第4个元素(左开右闭)
d1.erase(d1.begin() + , d1.begin() + );
11.容器的遍历
// 定义容器d2
deque<char> d2(,'A');
// 增强for遍历
for (char tmp : d2)
{
cout << tmp << " ";
}
cout << endl;
// 迭代器的正向遍历
for (deque<char>::iterator it = d2.begin(); it != d2.end(); it++)
{
cout << *it << " ";
}
cout << endl;
// 迭代器的反向遍历
for (deque<char>::reverse_iterator it = d2.rbegin(); it != d2.rend(); it++)
{
cout << *it << " ";
}
cout << endl;
12.容器的遍历删除
# include<iostream>
# include<deque> using namespace std; int main()
{
// 定义容器
deque<int> v;
// 添加数据
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();
// 这里注意不需要++it
for (deque<int>::iterator it = v.begin(); it != v.end();)
{
// 删除偶数
if (*it % == )
{
// erase删除该元素后返回下一个元素的迭代器
it = v.erase(it);
}
else {
it++;
}
}
// 遍历
for (int tmp : v)
{
cout << tmp << " ";
}
cout << endl; return ;
}
五,deque存储自定义数据类型
1.定义学生类
#pragma once
# include<iostream>
using namespace std; class Student
{
private:
char * name;
int age;
public:
Student();
Student(char * name, int age);
Student(const Student& student);
~Student();
public:
friend ostream& operator<<(ostream& out, Student& student);
};
2.学生类的实现
# define _CRT_SECURE_NO_WARNINGS
# include<iostream>
# include "Student.h"
using namespace std; /* 无参构造函数 */
Student::Student()
{
this->name = NULL;
this->age = ;
}
/* 有参构造函数 */
Student::Student(char * name, int age)
{
this->name = new char[strlen(name) + ];
strcpy(this->name, name);
this->age = age;
}
/* 拷贝构造函数 */
Student::Student(const Student& student)
{
this->name = new char[strlen(student.name) + ];
strcpy(this->name, student.name);
this->age = student.age;
}
/* 析构函数 */
Student::~Student()
{
if (this->name != NULL)
{
delete[] this->name;
this->name = NULL;
this->age = ;
} }
/* 左移操作符重载 */
ostream& operator<<(ostream& out, Student& student)
{
out << student.name << " = " << student.age;
return out;
}
3.测试类
# include<iostream>
# include<deque>
# include"Student.h"
using namespace std; int main()
{
// 定义自定义对象
Student s1("刘备", );
Student s2("关羽", );
Student s3("张飞", );
// 放入容器
deque<Student> d;
// 存入
d.push_back(s1);
d.push_back(s2);
d.push_back(s3);
// 遍历
for (Student stu : d)
{
cout << stu << endl;
} return ;
}
STL序列容器之deque的更多相关文章
- C++STL模板库序列容器之deque
目录 一丶队列容器deque简介 二丶使用代码演示 一丶队列容器deque简介 deque底层跟vector一样,都是数组维护.不同的是可以操作头部. 二丶使用代码演示 #define _CRT_SE ...
- STL序列容器之vector
一,vector容器简介 1.vector容器的原理 vector是将元素置于一个动态数组中加以管理的容器. 2.vector容器的特点 vector容器可以随机存取元素,支持索引存取(即用数组下标的 ...
- C++顺序容器之deque初探
C++顺序容器之deque初探 deque是双端队列,与vector非常相似,是顺序容器,不同的是,deque可以在数组开头和末尾插入和删除数据.支持快速随机访问. #include<iostr ...
- C++STL模板库序列容器之vector
目录 STL之Vecter 一丶STL简介 二丶Vector用法 1.vector容器的使用 2.vector迭代器. 3.vector中的方法. 三丶常用算法 1.常见算法中的算法方法. 2.sor ...
- C++STL模板库序列容器之List容器
目录 一丶List容器的存储结构 二丶丶STL中list容器的使用. 一丶List容器的存储结构 list容器底层是链表结构来维护的.跟vector不一样. vector是数组维护的.拥有连续内存.所 ...
- STL容器之deque
[1]deque容器 deque 是对 vector 和 list 优缺点的结合,它是处于两者之间的一种容器. [2]deque方法集 应用示例代码: #include <deque> # ...
- C++ STL 常用容器之 stack
C++ STL Container--Stack 栈是一种先进后出(LIFO)的数据结构,限制只能在一端完成插入和删除操作,这一端叫做栈顶(top),另一端即为栈底(bottom).C++ STL(S ...
- C++序列容器之 vector常见用法总结
一.关于vector 本文默认读者具有一定的c++基础,故大致叙述,但保证代码正确. vector是一个动态的序列容器,相当于一个size可变的数组. 相比于数组,vector会消耗更多的内存以有效的 ...
- [知识点]C++中STL容器之map
UPDATE(20190416):写完vector和set之后,发现不少内容全部引导到map上了……于是进行了一定的描述补充与更正. 零.STL目录 1.容器之map 2.容器之vector 3.容器 ...
随机推荐
- Css fixed和absolute定位差别
fixed:固定定位 absolute:绝对定位 差别非常easy: 1.没有滚动栏的情况下没有差异 2.在有滚动栏的情况下.fixed定位不会随滚动栏移动而移动.而absolute则会随滚动栏移动 ...
- 9.3 Binder系统_驱动情景分析_服务获取过程
4. 服务获取过程 test_client客户端: (1)在用户态先构造name=“hello”的数据(服务的名字是hello),调用ioctl发送数据给service_manager(handle= ...
- Spring-Boot整合freemarker引入静态资源css、js等(转)
一.概述 springboot 默认静态资源访问的路径为:/static 或 /public 或 /resources 或 /META-INF/resources 这样的地址都必须定义在src/mai ...
- FPGA实现UHS的一些资料
对使用FPGA和SD卡进行UHS模式通信的评估: 论文:基于FPGA的SD UHS-II卡控制器设计与实现 设计IP:SD UHS-II Host Controller 供应商: System Lev ...
- java.util.logging使用笔记2
java.util.logging是java自带的日志处理系统,其功能不如log4j/logback强大,但可以完成基本的日志需求. 另外,如果在一个项目中使用log4j, 而这个项目引用的第3方 ...
- 12、USB设备驱动程序
linux-3.4.2\driver\hid\usbhid\usbmouse.c 内核只带USB驱动程序 (hub和usb是两个不同的设备,hub在内核上电的过程中在usb_hub_init函数中调用 ...
- [转]在Win7 64位注册ActiveX控件
原文作者: K_H_H 原文地址: http://blog.sina.com.cn/s/blog_56b96c5a0100ztc7.html 首先必须以管理员身份运行cmd.exe,即在cmd.ex ...
- matlab 正则表达式
regexprep Replace text using regular expression collapse all in page Syntax newStr = regexprep(str,e ...
- MySQL误删数据救命指南
预防误操作导致文件/数据丢失的建议: 1.欲删除文件时,将rm命令改成mv,可在系统层面将rm命令做个alias(或参考Windows / Mac OSX做法,删除文件时先进回收站).2.删除数据库. ...
- 使用DatagramSocket与DatagramPacket传输数据 分类: B1_JAVA 2013-10-12 13:00 1936人阅读 评论(0) 收藏
参考传智播客毕向东JAVA视频. 注: DatagramSocket发送的每个包都需要指定地址,而Socket则是在首次创建时指定地址,以后所有数据的发送都通过此socket. A socket is ...