STL——deque容器【双端动态数组】

news2025/1/13 3:09:58

deque容器的基本概念:

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

deque与vector的区别:

  • vector队友头部的插入删除效率低,数据量越大,效率越低
  • deque相对而言,对头部的插入删除速度会比vector快
  • vector访问元素时的速度会比的deque快,这和两者内部实现有关

deque内部工作原理:

  • deque内部有个中控器,维护每段缓冲区的内容,缓冲区存放真实数据
  • 中控器维护的时每个缓冲区的地址,使得使用deque时像一片连续的内存空间 
  • deuqe的迭代器也支持随机访问

deque的构造函数:

函数原型:

  • deque<T> deqT:默认构造形式
  • deque(beg,end):构造函数将[beg,end)区间中的元素拷贝给本身
  • deque(n,elem):构造函数将n个elem拷贝给本身
  • deque(const deque &deq):拷贝构造函数
#include<bits/stdc++.h>
using namespace std;
void printdeque(const deque<int>&d){
	for(deque<int>::const_iterator it=d.begin();it!=d.end();it++){
		//*it=100; 容器里的数据不可以修改了 
		cout<<*it<<" ";
	} 
	cout<<endl;
} 
void test01(){
	deque<int> d1;
	for(int i=0;i<10;i++){
		d1.push_back(i);
	}
	printdeque(d1);
	
	
	deque<int>d2(d1.begin(),d1.end());
	printdeque(d2);
	
	deque<int>d3(10,100);
	printdeque(d3);
	
	deque<int>d4(d3);
	printdeque(d4);
}
int main(){
	test01();
	return 0;
} 

deque赋值操作:

函数原型:

  • deque& operator=(const deque &dec):重载等号操作符

  • assign(beg,end):将[beg,end)区间中的数据拷贝赋值给本身【前闭后开区间】

  • assign(n,elem):将n个elem拷贝赋值给本身

#include<bits/stdc++.h>
using namespace std;
void printdeque(deque<int> &d){
	for(deque<int>::iterator it=d.begin();it!=d.end();it++){
		cout<<*it<<" ";
	}
	cout<<endl;
}
void test01(){
	deque<int>d1;
	for(int i=0;i<10;i++){
		d1.push_back(i);
	}
	printdeque(d1);
	
	//operator赋值 
	deque<int>d2;
	d2=d1;
	printdeque(d2);
	
	//assign方式
	deque<int>d3;
	d3.assign(d1.begin(),d1.end()); 
	printdeque(d3);
	 
	deque<int>d4(10,100);
	printdeque(d4);
}
int main(){
	test01();
	
	
	return 0;
}

deque大小操作:

功能描述:对deque容器的大小进行操作

函数原型:

  • deque.empty():判断容器是否为空

  • deque.size():返回容器中元素的个数

  • deque.resize():重新指定容器的长度为num,若容器变长,则以默认值填充新位置,若容器变短,则末尾超出容器长度的元素被删除

  • deque.resize(num,elem):重新指定容器的长度为num,若容器变长,则以elem填充新位置,若容器变短,则末尾超出容器长度的元素被删除

#include<bits/stdc++.h>
using namespace std;
void printdeque(deque<int>&d){
	for(deque<int>::iterator it=d.begin();it!=d.end();it++){
		cout<<*it<<" ";
	}
	cout<<endl;
}
void test01(){
	deque<int>d1;
	for(int i=0;i<10;i++){
		d1.push_back(i);
	}
	printdeque(d1);
	if(d1.empty()){
		cout<<"d1为空"<<endl;
	}
	else {
		cout<<"d1不为空"<<endl;
		cout<<"d1的大小为:"<<d1.size()<<endl;
		//deque没有容量的概念
		 
	}
	//重新指定大小
	d1.resize(15); 
	printdeque(d1);
	d1.resize(15,1);
	printdeque(d1);
	
	d1.resize(3);
	printdeque(d1);
}
int main(){
	test01();
	
	
	return 0; 
}

deque的插入和删除:

函数原型:

两端插入操作:

  • push_back(elem):在容器尾部添加一个数据

  • push_front(elem):在容器头部插入一个数据

  • pop_back():删除容器最后一个数据

  • pop_front():删除容器第一个数据

指定位置操作:

  • insert(pos,elem):在pos位置插入一个elem元素的拷贝,返回新数据的位置

  • insert(pos,n,elem):在pos位置插入n个elem数据,无返回值

  • isnert(pos,beg,end):在pos位置插入[beg,ebd)区间的数据,无返回值

  • clear():清空容器所有数据

  • erase(beg,end):删除[beg,end)区间的数据,返回下一个数据的位置

  • erase(pos):删除pos位置的数据,返回下一个数据的位置

#include<bits/stdc++.h>
using namespace std;
void printdeque(deque<int>d){
	for(deque<int>::iterator it=d.begin();it!=d.end();it++){
		cout<<*it<<" ";
	}
	cout<<endl;
}
//两端操作 
void test01(){
	deque<int>d1;
	//尾插 
	d1.push_back(10);
	d1.push_back(20);
	
	//头插
	d1.push_front(1);
	d1.push_front(2);
	printdeque(d1);
	
	//尾部删除
	d1.pop_back();
	printdeque(d1);
	
	//头部删除
	d1.pop_front();
	printdeque(d1); 
}
void test02(){
	deque<int>d1;
	//尾插 
	d1.push_back(10);
	d1.push_back(20);
	
	//头插
	d1.push_front(1);
	d1.push_front(2);
	printdeque(d1);
	
	//insert插入
	d1.insert(d1.begin(),100);
	printdeque(d1); 
	
	//insert重载
	d1.insert(d1.begin(),2,1000);
	printdeque(d1); 
	
	//按照区间进行插入
	deque<int>d2;
	d2.push_back(1);
	d2.push_back(2);
	d2.push_back(3);
	
	d1.insert(d1.begin(),d2.begin(),d2.end());
	printdeque(d1); 
	 
}
//删除 
void test03(){
	deque<int>d1;
	d1.push_back(10);
	d1.push_back(20);
	d1.push_front(100);
	d1.push_front(200);
	deque<int>::iterator it=d1.begin();
	it++;
	d1.erase(it);
	printdeque(d1);
	
	//按照区间的方式删除
	d1.erase(d1.begin(),d1.end());
	//清空
	d1.clear(); 
	printdeque(d1); 
} 
int main(){
	test01();
	test02();
	test03();
	return 0;
}

 deque的数据存取:

函数原型:

#include<bits/stdc++.h>
using namespace std;
//deque容器数据存取
void test01(){
	deque<int>d;
	d.push_back(10);
	d.push_back(20);
	d.push_back(30);
	d.push_front(100);
	d.push_front(200);
	d.push_front(300);
	
	//通过[]访问元素
	for(int i=0;i<d.size();i++){
		cout<<d[i]<<" ";
	} 
	cout<<endl;
	
	//通过at方式访问元素
	for(int i=0;i<d.size();i++) {
		cout<<d.at(i)<<" ";
	}
	cout<<endl;
	 
	 //访问头尾元素 
	 cout<<"第一个元素为:"<<d.front()<<endl;
	 cout<<"最后一个元素为:"<<d.back()<<endl; 
} 
int main(){
	test01(); 	
	return 0;
}

deque的排序:

算法:

  • sort(iterator beg,iterator end):对bg和end区间内的元素进行排序

#include<bits/stdc++.h>
using namespace std;
void printdeque(deque<int>d){
	for(deque<int>::iterator it=d.begin();it!=d.end();it++){
		cout<<*it<<" ";
	}
	cout<<endl;
}
int cmp(int a,int b){
	return a>b;
} 
void test01(){
	deque<int> d;
	d.push_back(10);
	d.push_back(20);
	d.push_back(30);
	d.push_front(100);
	d.push_front(200);
	d.push_front(300);
	printdeque(d);
	
	//排序,默认升序排序 
	sort(d.begin(),d.end());
	printdeque(d); 
	
	//降序排序
	sort(d.begin(),d.end(),cmp);
	printdeque(d);
}
int main(){
	test01();
	
	
	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1675433.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

银行业数据运营场景下的数据埋点方案

1、引言 随着金融科技的快速发展&#xff0c;银行业的数据运营变得日益重要。数据埋点作为数据收集的重要手段&#xff0c;对于银行业务的精细化运营、风险管理和产品迭代等方面起着至关重要的作用。本方案将针对银行业数据运营场景&#xff0c;设计一套完整的数据埋点方案&am…

OFDM802.11a的FPGA实现(十五)短训练序列:STS(含Matlab和verilog代码)

原文链接&#xff08;相关文章合集&#xff09;&#xff1a;OFDM 802.11a的xilinx FPGA实现 1.前言 在之前已经完成了data域数据的处理&#xff0c;在构建整个802.11a OFDM数据帧的时候&#xff0c;还剩下前导码和signal域的数据帧&#xff0c;这两部分的内容。 PLCP的前导部分…

景源畅信:抖音小店比较冷门的品类分享?

在抖音小店的世界里&#xff0c;热门品类总是吸引着众多商家和消费者的目光。然而&#xff0c;就像星空中的繁星&#xff0c;虽不那么耀眼却依然存在的冷门品类同样值得我们关注。它们或许不似服装、美妆那样日进斗金&#xff0c;但正是这些小众市场的存在&#xff0c;为平台带…

如何对基本公共服务均等化进行统计监测

党的十九大指出“履行好政府再分配调节职能&#xff0c;加快推进基本公共服务均等化&#xff0c;缩小收入分配差距”&#xff0c;提出到2035年基本公共服务均等化基本实现。国务院相继于2012年和2017年发布了《国家基本公共服务体系“十二五”规划》和《“十三五”推进基本公共…

MySQL、JDBC复盘及规划

数据库仍有习题尚未做完&#xff0c;策略从一天做完改为每天5到10题&#xff0c;以此达到掌握和复习的效果&#xff0c;JDBC的六部仍需每天练习&#xff0c;从明天开始正式进行JavaWeb的学习&#xff0c;预计持续到七月中旬&#xff0c;还会完成一个书城项目&#xff0c;六月底…

安全风险 - 如何解决 setAccessible(true) 带来的安全风险?

可能每款成熟的金融app上架前都会经过层层安全检测才能执行上架&#xff0c;所以我隔三差五就能看到安全检测报告中提到的问题&#xff0c;根据问题的不同级别&#xff0c;处理的优先级也有所不同&#xff0c;此次讲的主要是一个 “轻度问题” &#xff0c;个人认为属于那种可改…

【研发日记】Matlab/Simulink技能解锁(七)——两种复数移相算法

复数移相&#xff0c;也称为复数相位旋转&#xff0c;就是在原有复数的基础上&#xff0c;不改变模数&#xff0c;只把相位角做一定的偏移。 文章目录 前言 三角函数移相 复数乘法移相 分析和应用 总结 前言 见《【研发日记】Matlab/Simulink技能解锁(二)——在Function编…

mysql的隔离性——MVCC

MVCC通过undolog版本链和readview来实现 更新和删除时会写入undolog中。 读已提交&#xff1a;在事务任意读时创建readview&#xff0c;读最新提交的事务 可重复读&#xff1a;在事务第一次读时创建readview

媒体宣发:多元宣发方式的方式有哪些

在信息爆炸的今天&#xff0c;媒体宣发被广泛地运用在各个领域&#xff0c;对于产品宣传、企业形象塑造等都起着至关重要的作用。多样化的媒体宣发方式越来越受到企业的重视&#xff0c;那么常见的媒体宣发方式有哪些呢&#xff1f; 首先&#xff0c;新闻发布是最传统也是最直…

[动画详解]LeetCode151.翻转字符串里的单词

&#x1f496;&#x1f496;&#x1f496;欢迎来到我的博客&#xff0c;我是anmory&#x1f496;&#x1f496;&#x1f496; 又和大家见面了 欢迎来到动画详解LeetCode算法系列 用通俗易懂的动画让算法题不再神秘 先来自我推荐一波 个人网站欢迎访问以及捐款 推荐阅读 如何低成…

深入理解K8S【安全认证机制kubectlconfig】

深入理解K8S【安全认证机制】 1 核心概念 1.1 安全体系 对于大型系统来说&#xff0c;对业务的权限、网络的安全认证是必不可少的。 对于linux系统来说&#xff0c;用户和组、文件权限、SELinux、防火墙、pam、sudo等&#xff0c;究其核心的目的都是为了保证系统是安全的。 …

利用CAD绘制角度斜线的简易指南---模大狮模型网

在CAD设计中&#xff0c;绘制角度斜线是常见的需求&#xff0c;尤其在工程、建筑等领域中。正确绘制角度斜线不仅可以提高图纸的清晰度和美观度&#xff0c;还有助于准确表达设计意图。本文将介绍如何利用CAD软件进行角度斜线的绘制&#xff0c;为您提供简明易懂的操作指南。 一…

对接极速行情丨DolphinDB MDL 行情插件使用指南

通联数据依托于金融大数据&#xff0c;结合人工智能技术为投资者提供个性化、智能化、专业化投资服务&#xff0c; MDL 则是通联数据提供的高频行情数据服务。DolphinDB 提供了能够从 MDL 服务器获取高频行情数据的 DolphinDB MDL 插件&#xff0c;帮助用户方便地通过 DolphinD…

FreeRTOS【4】线程挂起和恢复

1.开发背景 基于上一篇指引&#xff0c;成功创建并启动线程后&#xff0c;线程已经开始运行了&#xff0c;但是有时我们需要线程暂停运行&#xff0c;例如某个线程是控制 LED 闪灯的&#xff0c;如果现在需要让 LED 停止工作&#xff0c;单纯的关闭 LED 是没用的&#xff0c;因…

想要安装Word、Excel、PowerPoint,但却找不到对应软件?

前言 前几天有小伙伴在找Word和Excel软件&#xff0c;但找了半天都没发现怎么安装。 这件事情其实很简单&#xff0c;那就是Word、Excel并不是单独的一个个软件&#xff0c;而是集成在MS Office套件里的。 咱们大部分人常用的办公软件大概是Word、Excel和PowerPoint这三个。还…

ros键盘控制程序teleop_twist_keyboard 键值含义及用法

在机器人仿真中&#xff0c; 经常会用到键盘控制程序teleop_twist_keyboard 对机器人进行控制。但是对各个键值是何种含义&#xff0c; 如何操作并没有任何资料介绍,初次使用时会不知所措。 通过实践&#xff0c; 发现各个键值的作用如下&#xff1a; u-- 向左前方前进 i-- 直…

C#实现长方体棱锥圆柱棱柱圆锥展开折叠旋转缩放

C#实现长方体棱锥圆柱棱柱圆锥展开折叠旋转缩放 C#实现 模型边数 长方体 棱锥 圆柱 棱柱 圆锥 实现功能 展开 折叠 颜色 边框颜色 旋转 缩放 大小 视图方向 项目获取&#xff1a; 项目获取&#xff1a;typora: typora/img (gitee.com) 备用项目获取链接1&#xff1a;yife…

LangChain-Chatchat 实践

1. 说明 比较了几个AI LLM的集成应用工具(比如Quivr, Dify, one-api), 还是LangChain-Chatchat更符合我的需要: 支持私有化部署不同的LLM知识库支持Api支持开源免费, 容易二开 相关路径: 条项路径LangChain-Chatchat 项目/data0/Projects/Langchain-ChatchatLLM 语言模型保…

Python爬虫——如何使用urllib的HTTP基本库

怎样通过 urllib库 发送 HTTP 请求&#xff1f; urllib库主要由四个模块组成: urllib.request 打开和读取 URLurllib.error 包含 urllib.request 抛出的异常urllib.parse 用于解析 URLurllib.robotparser 用于解析 robots.txt 文件 1. 使用urllib.parse解析URL 使用urlparse(…

spring boot3多模块项目工程搭建-下(团队开发模板)

⛰️个人主页: 蒾酒 &#x1f525;系列专栏&#xff1a;《spring boot实战》 目录 写在前面 上文衔接 Common模块 DAO模块 Service模块 Web模块 API模块 写在最后 写在前面 本文介绍了springboot开发后端服务&#xff0c;多模块项目工程搭建&#xff0c;各模块的…