STL容器deque 的常用功能和操作

2024-08-30 06:12

本文主要是介绍STL容器deque 的常用功能和操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 C++ 的标准模板库(STL)中,std::deque(双端队列)是一种非常灵活且高效的容器。它允许在两端进行快速的插入和删除操作,非常适合需要在两端频繁操作的数据结构场景。与 std::vector 不同,std::deque 不是一个连续内存块的容器,而是由多个内存块构成,这使得它在两端操作时非常高效

目录

deque的常见创建方式

deque常用成员函数

 std::deque 的应用场景


deque的常见创建方式

#include <deque>
#include <iostream>
#include <vector>int main() {// 1. 创建一个空的 dequestd::deque<int> dq1;// 2. 创建一个包含 5 个元素的 deque,每个元素的值为 10std::deque<int> dq2(5, 10);for (int value : dq2) {std::cout << value << " "; // 输出:10 10 10 10 10}std::cout << std::endl;// 3. 使用初始化列表创建 dequestd::deque<int> dq3{1, 2, 3, 4, 5};for (int value : dq3) {std::cout << value << " "; // 输出:1 2 3 4 5}std::cout << std::endl;// 4. 从另一个 deque 复制构造std::deque<int> dq4(dq3);for (int value : dq4) {std::cout << value << " "; // 输出:1 2 3 4 5}std::cout << std::endl;// 5. 从 vector 的迭代器范围创建 dequestd::vector<int> vec{1, 2, 3, 4, 5};std::deque<int> dq5(vec.begin(), vec.end());for (int value : dq5) {std::cout << value << " "; // 输出:1 2 3 4 5}std::cout << std::endl;// 6. 使用移动构造函数创建 dequestd::deque<int> dq6{1, 2, 3, 4, 5};std::deque<int> dq7(std::move(dq6)); // 移动构造函数for (int value : dq7) {std::cout << value << " "; // 输出:1 2 3 4 5}std::cout << std::endl;return 0;
}

deque常用成员函数

  • push_front(const T& value):在双端队列的前面插入元素。

    dq.push_front(1); // 在队列前面插入 1
    
  • push_back(const T& value):在双端队列的后面插入元素。

    dq.push_back(2); // 在队列后面插入 2
    
  • pop_front():删除双端队列的第一个元素。

    dq.pop_front(); // 删除第一个元素
    
  • pop_back():删除双端队列的最后一个元素。

    dq.pop_back(); // 删除最后一个元素
    
  • front():访问双端队列的第一个元素。

    int first = dq.front(); // 获取第一个元素
    
  • back():访问双端队列的最后一个元素。

    int last = dq.back(); // 获取最后一个元素
    
  • at(size_t pos):访问指定位置的元素,带边界检查。

    int element = dq.at(2); // 获取第 3 个元素(索引从 0 开始)
    
  • size():返回双端队列中元素的个数。

    size_t n = dq.size(); // 获取元素个数
    
  • empty():检查双端队列是否为空。

    bool isEmpty = dq.empty(); // 如果为空则返回 true
    
  • clear():清空双端队列中的所有元素。

    dq.clear(); // 清空所有元素
    
  • begin() 和 end():返回指向容器起始和结束的迭代器。

    auto it = dq.begin(); // 指向第一个元素
    auto it_end = dq.end(); // 指向最后一个元素之后
    
  • rbegin() 和 rend():返回反向迭代器,用于从后向前遍历。

    auto rit = dq.rbegin(); // 指向最后一个元素
    auto rit_end = dq.rend(); // 指向第一个元素之前
    

 std::deque 的应用场景

  • 双端队列:当需要从两端进行高效的插入和删除操作时,如实现双端队列(deque)或队列(queue)数据结构。

  • 缓存机制:在实现缓存机制时,可能需要在数据结构的两端频繁地插入和删除元素,std::deque 可以提供有效的支持。

  • 移动窗口算法:在某些算法中,如滑动窗口技术,std::deque 能够提供灵活的窗口操作。

这篇关于STL容器deque 的常用功能和操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1120012

相关文章

MyBatis常用XML语法详解

《MyBatis常用XML语法详解》文章介绍了MyBatis常用XML语法,包括结果映射、查询语句、插入语句、更新语句、删除语句、动态SQL标签以及ehcache.xml文件的使用,感兴趣的朋友跟随小... 目录1、定义结果映射2、查询语句3、插入语句4、更新语句5、删除语句6、动态 SQL 标签7、ehc

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

Python打包成exe常用的四种方法小结

《Python打包成exe常用的四种方法小结》本文主要介绍了Python打包成exe常用的四种方法,包括PyInstaller、cx_Freeze、Py2exe、Nuitka,文中通过示例代码介绍的非... 目录一.PyInstaller11.安装:2. PyInstaller常用参数下面是pyinstal

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

Python内存管理机制之垃圾回收与引用计数操作全过程

《Python内存管理机制之垃圾回收与引用计数操作全过程》SQLAlchemy是Python中最流行的ORM(对象关系映射)框架之一,它提供了高效且灵活的数据库操作方式,本文将介绍如何使用SQLAlc... 目录安装核心概念连接数据库定义数据模型创建数据库表基本CRUD操作创建数据读取数据更新数据删除数据查

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Java JUC并发集合详解之线程安全容器完全攻略

《JavaJUC并发集合详解之线程安全容器完全攻略》Java通过java.util.concurrent(JUC)包提供了一整套线程安全的并发容器,它们不仅是简单的同步包装,更是基于精妙并发算法构建... 目录一、为什么需要JUC并发集合?二、核心并发集合分类与详解三、选型指南:如何选择合适的并发容器?在多