news 2026/4/3 4:15:10

STL容器——deque容器

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
STL容器——deque容器

deque容器

  • 'double-ended queue’的缩写,和vector一样都是STL的容器
  • deque是双端数组,可以对头部进行插入删除操作,相较于vector多了头插头删的操作以及front()和back(),后面这两个分别表示容器的第一个元素和最后一个元素,并不是迭代器,调用会得到具体值

deque与vector的区别:

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

函数原型

deque deq;功能
deque deq;其中T是泛型,用来存放数据类型,这是默认构造函数,较为常用
deque(deq.begin(), deq.end());将[deq.begin(),deq.end)前闭后开的区间内的元素拷贝给本身容器
deque(n,elem);构造函数将n个elem值拷贝给本身容器
deque(const deque &ans);拷贝构造函数

代码示例

#include<iostream>usingnamespacestd;#include<deque>voidprintDeque(constdeque<int>&d)//只读容器不可改{//迭代器变为 const_iteratorfor(deque<int>::const_iterator it=d.begin();it!=d.end();it++){cout<<*it<<" ";}cout<<endl;}voidtset1(){//默认构造deque<int>d1;for(inti=0;i<10;i++){d1.push_back(i);}printDeque(d1);//区间构造deque<int>d2(d1.begin(),d1.end());printDeque(d2);//赋值构造deque<int>d5(7);printDeque(d5);//赋值构造deque<int>d3(7,5);printDeque(d3);//拷贝构造deque<int>d4(d3);printDeque(d4);}intmain(){test1();system("pause");return0;}

赋值

  • deque& operator=(const deque &ans);重载赋值操作符
  • assign(be,en);将[be,en);将[be,en)区间内的数组拷贝赋值给自己
  • assign(n,elem);将n个elem拷贝赋值给自己
voidtestb(){deque<int>d1;for(inti=0;i<10;i++){d1.push_back(i);}//第一种deque<int>d2=d1;//第二种deque<int>d3;d3.assign(d1.begin(),d1.end());//第三种deque<int>d4;d4.assign(6,88);//测试:printDeque(d2);printDeque(d3);printDeque(d4);}

容器大小

对deque的大小进行操作

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

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

deque.resize(m);重新指定容器长度为num,容器变长以默认值填充,容器变短则超出部分删除

deque.resize(m,elem);同上,区别是默认值填充变为elem

注意deque没有容量概念

判断是否为空——empty

返回元素个数——size

重新指定个数——reseize

插入和删除

  • 两端操作:

    • push_back(e);尾插
    • push_front(e);头插
    • pop_back();尾删
    • pop_front();头删
  • 指定位置:

    • insert(const_iterator pos,e);迭代器指向位置pos插入指定元素e

    • insert(const_iterator pos,int count ,e);插入count个指定元素e

    • insert(const_iterator pos,beg,en);插入指定区域的元素

    • erase(const_iterator pos);删除迭代器指向的元素

    • erase(const_iterator begin,const_iterator end);删除迭代器从begin到end之间的元素

    • clear();清空容器内所有元素

//两端操作voidtest01(){deque<int>d1;//尾插d1.push_back(10);d1.push_back(20);//头插d1.push_front(100);d1.push_front(200);PrintDeque(d1);//尾删d1.pop_back();PrintDeque(d1);//头删d1.pop_front();PrintDeque(d1);}voidtest02(){deque<int>d2;//尾插d2.push_back(10);d2.push_back(20);//头插d2.push_front(100);d2.push_front(200);PrintDeque(d2);//insert插入d2.insert(d2.begin(),1000);PrintDeque(d2);d2.insert(d2.begin(),2,10000);PrintDeque(d2);//按照区间进行插入deque<int>d3;d3.push_back(1);d3.push_back(2);d3.push_back(3);d2.insert(d2.begin(),d3.begin(),d3.end());PrintDeque(d2);}voidtest03(){deque<int>d4;//尾插d4.push_back(10);d4.push_back(20);//头插d4.push_front(100);d4.push_front(200);PrintDeque(d4);//删除deque<int>::iterator it=d4.begin();it++;d4.erase(it);PrintDeque(d4);//按照区间方式删除d4.erase(d4.begin(),d4.end());PrintDeque(d4);//清空d4.clear();PrintDeque(d4);}

数据存取

  • 对deque中的元素进行存取操作

函数原型:

  • at(int dex);返回索引dex所指的数据

  • operator[];同上

  • front();返回容器中第一个数据

  • back();返回容器中最后一个数据

    //通过[]方式访问元素
    for (int i = 0; i < d1.size(); i++)
    {
    cout << d1[i] << " ";
    }
    cout << endl;
    //通过at方式访问元素
    for (int i = 0; i < d1.size(); i++)
    {
    cout << d1.at(i) << " ";
    }

排序

  • 需要引入头文件:<algorithm>
  • 利用算法实现对deque容器的排序
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/1 6:02:02

详细分析一下 国富论里里面 十一章 关于白银价格的 论述

《国富论》第十一章《论地租》中关于白银价格的论述&#xff0c;并非独立的货币理论章节&#xff0c;而是斯密为了论证其地租理论而引入的一个关键历史证据和比较分析。其核心目的在于&#xff1a;驳斥重商主义关于“金银即财富”的谬误&#xff0c;并论证土地的真实地租&#…

作者头像 李华
网站建设 2026/4/2 22:17:54

从 0 到 1 掌握 Flutter 状态管理:Provider 实战与原理剖析

欢迎大家加入[开源鸿蒙跨平台开发者社区](https://openharmonycrossplatform.csdn.net)&#xff0c;一起共建开源鸿蒙跨平台生态。 在 Flutter 开发中&#xff0c;状态管理始终是绕不开的核心话题。随着应用复杂度的提升&#xff0c;如何高效、优雅地管理状态数据成为了每个 F…

作者头像 李华
网站建设 2026/4/3 3:20:26

COMSOL 模型:纳米粒子等离子体增强效应的分析

COMSOL纳米粒子等离子体增强效应模型在现代科学和技术发展中&#xff0c;纳米尺度的粒子因其独特的物理和化学性质&#xff0c;广泛应用于材料科学、生物医学、环境治理等领域。特别是在等离子体增强效应&#xff08;Plasma-enhanced Deposition or PE Desired&#xff09;方面…

作者头像 李华
网站建设 2026/3/14 11:35:19

12、网络队列、流量整形与冗余配置全解析

网络队列、流量整形与冗余配置全解析 在网络管理中,为了满足不同的网络需求,如保障关键服务的带宽、处理冗余和故障转移等,我们需要运用多种技术手段。下面将详细介绍基于类的带宽分配、DMZ 服务器队列配置、处理不需要的流量以及冗余和故障转移等方面的内容。 基于类的小…

作者头像 李华
网站建设 2026/3/31 6:10:06

K8s 配置管理:ConfigMap 与 Secret 生产级专业指南

从基础用法到真实踩坑,再到 GitOps 与安全加固的完整实践 一、为什么需要 ConfigMap 与 Secret? 1.1 传统配置管理的三大痛点(真实生产视角) 在容器化之前,配置通常以以下方式存在: 配置硬编码在代码或镜像中 多环境靠手工改配置文件 密码、Token 明文出现在 Git 仓库或…

作者头像 李华
网站建设 2026/3/31 12:25:01

【数据库】【Redis】数据结构全景图:命令、场景与避坑指南

Redis 数据结构全景表格数据结构核心命令使用场景String&#xff08;字符串&#xff09;SET, GET, INCR, DECR, APPEND, STRLEN, MSET, MGET缓存对象、计数器、分布式锁、Session存储、限速器Hash&#xff08;哈希表&#xff09;HSET, HGET, HGETALL, HDEL, HINCRBY, HLEN, HMS…

作者头像 李华