C++中deque的用法(超详细,入门必看)

简介: ⭐一、deque的简介deque是一个双向队列(double-ended queue),可以在队列的两端进行元素的插入和删除操作。deque的全称是double-ended queue,翻译过来就是双端队列,也有人称之为双向队列,这两个名称都可以表示该数据结构。deque是C++STL(标准模板库)中的一种容器,可以用于存储各种类型的元素。deque的特点是可以在队列的两端进行元素的操作,并且可以高效地在队列的任意位置进行元素的插入和删除操作。可以说deque几乎涵盖了queue(队列)、stack(堆栈)、vector(向量 )等的全部用法,功能非常的强大。

⭐一、deque的简介

deque是一个双向队列(double-ended queue),可以在队列的两端进行元素的插入和删除操作。deque的全称是double-ended queue,翻译过来就是双端队列,也有人称之为双向队列,这两个名称都可以表示该数据结构。deque是C++STL(标准模板库)中的一种容器,可以用于存储各种类型的元素。deque的特点是可以在队列的两端进行元素的操作,并且可以高效地在队列的任意位置进行元素的插入和删除操作。

可以说deque几乎涵盖了queue(队列)、stack(堆栈)、vector(向量 )等的全部用法,功能非常的强大。

使用queue时需要包含头文件:

 #include<deque>

⭐二、deque的定义及初始化

  • 定义
    deque<数据类型>容器名
    例:
//deque的定义 
deque<int>d1; //定义一个储存数据类型为int的双端队列d1 
deque<double>d2; //定义一个储存数据类型为double的双端队列d2 
deque<string>d3; //定义一个储存数据类型为string的双端队列d3 
deque<结构体类型>d4; //定义一个储存数据类型为结构体类型的双端队列d4 
deque<int> d5[N]; //定义一个储存数据类型为int的双端队列数组d5 
deque<double>d6[N]; //定义一个储存数据类型为double的双端队列数组d6 

⭐三、deque的成员函数

关于deque的常用函数:

push_back()//在队列的尾部插入元素。
emplace_front()//与push_front()的作用一样 
push_front()//在队列的头部插入元素。
emplace_back()//与push_back()的作用一样 
pop_back()//删除队列尾部的元素。
pop_front()//删除队列头部的元素。
back()//返回队列尾部元素的引用。
front()//返回队列头部元素的引用。
clear()//清空队列中的所有元素。
empty()//判断队列是否为空。
size()//返回队列中元素的个数。
begin()//返回头位置的迭代器
end()//返回尾+1位置的迭代器
rbegin()//返回逆头位置的迭代器 
rend()//返回逆尾-1位置的迭代器 
insert()//在指定位置插入元素 
erase()//在指定位置删除元素 
push_bac

示例代码:

#include<iostream>
#include<deque>
using namespace std;
int main()
{
  deque<int> d; //定义一个数据类型为int的deque
  d.push_back(1); //向队列中加入元素1 
  d.push_back(2); //向队列中加入元素2
  d.push_back(3); //向队列中加入元素3
  d.push_back(4); //向队列中加入元素4
  cout<<"双端队列中现在的元素为:"<<endl;
  for(int i=0;i<d.size();i++)
  {
    cout<<d[i]<<" ";
  }
  cout<<endl;
  d.pop_front();
  cout<<"弹出队首元素后,双端队列中现在的元素为:"<<endl;
  for(int i=0;i<d.size();i++)
  {
    cout<<d[i]<<" ";
  }
  cout<<endl;
  d.pop_back();
  cout<<"弹出队尾元素后,双端队列中现在的元素为:"<<endl;
  for(int i=0;i<d.size();i++)
  {
    cout<<d[i]<<" ";
  }
  cout<<endl;
  d.push_back(6);
  cout<<"在队尾添加元素6后,双端队列中现在的元素为:"<<endl;
  for(int i=0;i<d.size();i++)
  {
    cout<<d[i]<<" ";
  }
  cout<<endl;
  d.push_front(8);
  cout<<"在队首添加元素8后,双端队列中现在的元素为:"<<endl;
  for(int i=0;i<d.size();i++)
  {
    cout<<d[i]<<" ";
  }
}

运行结果:

双端队列中现在的元素为:
1 2 3 4
弹出队首元素后,双端队列中现在的元素为:
2 3 4
弹出队尾元素后,双端队列中现在的元素为:
2 3
在队尾添加元素6后,双端队列中现在的元素为:
2 3 6
在队首添加元素8后,双端队列中现在的元素为:
8 2 3 6

⭐四、deque的遍历方法

  • 1.通过迭代器iterator遍历
#include<iostream>
#include<deque>
using namespace std;
int main()
{
  deque<int> d; //定义一个数据类型为int的deque
  d.push_back(1); //向队列中加入元素1 
  d.push_back(2); //向队列中加入元素2
  d.push_back(3); //向队列中加入元素3
  d.push_back(4); //向队列中加入元素4
  deque<int>::iterator it;
  for(it=d.begin();it!=d.end();it++)
  {
    cout<<*it<<" ";
  }
}

运行结果:

11 2 3 4
  • 2.通过下标遍历
#include<iostream>
#include<deque>
using namespace std;
int main()
{
  deque<int> d; //定义一个数据类型为int的deque
  d.push_back(1); //向队列中加入元素1 
  d.push_back(2); //向队列中加入元素2
  d.push_back(3); //向队列中加入元素3
  d.push_back(4); //向队列中加入元素4
  for(int i=0;i<d.size();i++)
  {
    cout<<d[i]<<" ";
  }
}

运行结果:

1 2 3 4
  • 3.通过foreach遍历
#include<iostream>
#include<deque>
using namespace std;
int main()
{
  deque<int> d; //定义一个数据类型为int的deque
  d.push_back(1); //向队列中加入元素1 
  d.push_back(2); //向队列中加入元素2
  d.push_back(3); //向队列中加入元素3
  d.push_back(4); //向队列中加入元素4
  for(int it:d)
  {
    cout<<it<<" ";
  }
}

运行结果:

1 2 3 4

⭐五、写在最后

OK本文的学习就到此结束啦,希望本文可以帮助到各位有需要的小伙伴们喔,也希望各位小伙伴们可以不要吝惜手里的三连哦!感谢你们的支持,你们的支持就是我创作最大的动力哦!❤️❤️❤️

💕 回头看,轻舟已过万重山,向前看,前路漫漫亦漫漫。

相关文章
|
3天前
|
编译器 C语言 C++
【C++】学习笔记——C++入门_2
【C++】学习笔记——C++入门_2
15 6
|
3天前
|
安全 编译器 C语言
【C++】学习笔记——C++入门_3
【C++】学习笔记——C++入门_3
19 4
|
3天前
|
程序员 编译器 C语言
【C++】学习笔记——C++入门_1
【C++】学习笔记——C++入门_1
13 4
|
2天前
|
C++ 容器
C++之评委打分案例(vector与deque容器练习)
C++之评委打分案例(vector与deque容器练习)
8 1
|
2天前
|
C++ 容器
C++之deque容器(构造、赋值、大小、插入与删除、存取、排序)
C++之deque容器(构造、赋值、大小、插入与删除、存取、排序)
5 1
|
3天前
|
安全 编译器 程序员
【C++初阶】--- C++入门(上)
【C++初阶】--- C++入门(上)
9 1
|
7天前
|
存储 算法 C++
C++一分钟之-容器概览:vector, list, deque
【6月更文挑战第21天】STL中的`vector`是动态数组,适合随机访问,但插入删除非末尾元素较慢;`list`是双向链表,插入删除快但随机访问效率低;`deque`结合两者优点,支持快速双端操作。选择容器要考虑操作频率、内存占用和性能需求。注意预分配容量以减少`vector`的内存重分配,使用迭代器而非索引操作`list`,并利用`deque`的两端优势。理解容器内部机制和应用场景是优化C++程序的关键。
20 5
|
4天前
|
安全 编译器 C语言
C++练级之路——C++入门
C++练级之路——C++入门
9 1
|
9天前
|
C++
C++类和类模板——入门
C++类和类模板——入门
11 1
|
10天前
|
存储 C++ 容器
C++一分钟之-变量与数据类型入门
【6月更文挑战第18天】**C++编程基础:变量与数据类型概览** 了解变量(存储数据的容器)和数据类型是编程入门的关键。声明变量如`int age = 25;`,注意初始化和类型匹配。基本数据类型包括整型(int等)、浮点型(float、double)、字符型(char)和布尔型(bool)。理解类型范围和精度,使用字面量后缀增强可读性。深入学习数组、指针、结构体和类,以及动态内存管理,避免数组越界和内存泄漏。不断实践以巩固理论知识。
20 1