【C++ 十三】C++ deque容器

本文详细介绍了C++中的deque容器,包括其作为双端数组的特点、与vector的区别、内部工作原理以及构造、赋值、大小操作、插入删除、数据存取和排序等方法,并通过示例代码展示了具体用法。deque在头部插入删除操作上比vector更高效,但在访问速度上较慢,适用于需要频繁在两端操作的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C++ deque 容器



前言

本文包含deque容器基本概念、deque构造函数、deque赋值操作、deque大小操作、deque插入和删除、deque数据存取、deque排序。


1 deque 容器基本概念

功能: 双端数组,可以对头端进行插入删除操作

deque 与 vector 区别:

(1)、vector 对于头部的插入删除效率低,数据量越大,效率越低

(2)、deque 相对而言,对头部的插入删除速度回比 vector 快

(3)、vector 访问元素时的速度会比 deque 快,这和两者内部实现有关

在这里插入图片描述

deque 内部工作原理:

(1)、deque 内部有个中控器,维护每段缓冲区中的内容,缓冲区中存放真实数据

(2)、中控器维护的是每个缓冲区的地址,使得使用 deque 时像一片连续的内存空间

(3)、deque 容器的迭代器也是支持随机访问的

在这里插入图片描述

2 deque 构造函数

功能描述: deque 容器构造

函数原型:

(1)、deque<T> deqT; 默认构造形式

(2)、deque(beg, end); 构造函数将 [beg, end) 区间中的元素拷贝给本身

(3)、deque(n, elem); 构造函数将 n 个 elem 拷贝给本身

(4)、deque(const deque &deq); 拷贝构造函数

// deque双端数组容器构造函数

#include <iostream>  // 包含标准输入输出流头文件
using namespace std;  // 使用标准命名空间

#include <deque>  // 使用deque双端数组容器,需包含头文件deque

// const对此容器只是只读,不可以修改
void Fun_Print(const deque<int>& d) {
   
      // 使用引用方式&,传入deque<int>类型的形参d

	// deque<int>::iterator 拿到deque<int>这种容器的迭代器类型;每个容器都有一个专属的迭代器类型
	// const_iterator只读迭代器;iterator普通迭代器
	for (deque<int>::const_iterator it = d.begin(); it != d.end(); it++) {
   
   

		//*it= 100;  // 报错,容器中数据不可修改:表达式必须是可修改的左值

		cout << *it << " ";  // it是个迭代器类型,本是是个指针,需使用*解引用
	}
	cout << endl;
}

void test() {
   
   

	// 1、默认构造方式,无参构造
	deque<int> d;

	for (int i = 0; i < 10; i++)
	{
   
   
		// push_back()向容器尾部插入数据i
		d.push_back(i);
	}
	Fun_Print(d);  // 0 1 2 3 4 5 6 7 8 9

	// 2、将d容器开始迭代器到结束迭代器之间的数据元素,拷贝给d1容器
	deque<int> d1(d.begin(), d.end());
	Fun_Print(d1);  // 0 1 2 3 4 5 6 7 8 9

	// 3、将10个100拷贝给d2容器
	deque<int> d2(10, 100);
	Fun_Print(d2);  // 100 100 100 100 100 100 100 100 100 100

	// 4、拷贝构造
	deque<int> d3(d2);
	Fun_Print(d3);  // 100 100 100 100 100 100 100 100 100 100
}

int main() {
   
   

	test();

	system("pause");  // 相当于在本地 Windows 调试器中的:请按任意键继续...;暂停,方便看清楚输出结果

	return 0;  // 程序正常退出
}

在这里插入图片描述

3 deque 赋值操作

功能描述: 给 deque 容器进行赋值

函数原型:

(1)、deque& operator=(const deque &deq); 重载等号操作符

(2)、assign(beg, end); 将 [beg, end) 区间中的数据拷贝赋值给本身

(3)、assign(n, elem); 将 n 个 elem 拷贝赋值给本身

// deque双端数组容器赋值

#include <iostream>  // 包含标准输入输出流头文件
using namespace std;  // 使用标准命名空间

#include <deque>  // 使用deque双端数组容器,需包含头文件deque

// const对此容器只是只读,不可以修改
void Fun_Print(const deque<int>& d) {
   
      // 使用引用方式&,传入deque<int>类型的形参d

	// deque<int>::iterator 拿到deque<int>这种容器的迭代器类型;每个容器都有一个专属的迭代器类型
	// const_iterator只读迭代器;iterator普通迭代器
	for (deque<int>::const_iterator it = d.begin(); it != d.end(); it++) {
   
   

		//*it= 100;  // 报错,容器中数据不可修改:表达式必须是可修改的左值

		cout << *it << " "
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小鹿快跑~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值