C++:SLT容器-->deque

在这里插入图片描述

C++:SLT容器-->deque

        • 1. 构造函数
        • 2. deque 赋值操作
        • 3. deque 大小操作
        • 4. deque 插入和删除
        • 5. deque 容器数据存取
        • 6. deque 排序操作

双端数组,可以对头部和尾部进行插入删除操作
==需要导入头文件#include <deque>==

1. 构造函数

deque deqT; // 默认构造函数
deque(beg,end); // 构造函数将(beg,end)区间中的元素拷贝给本身
deque(n,ele); // 构造函数将n个ele拷贝给本身
deque(const deque &deq); // 拷贝构造函数

#include <iostream>
#include <deque>

using namespace std;



void printDeque(deque<int>& d){
    for(deque<int>::const_iterator it = d.begin();it!=d.end();it++){
        cout << *it << endl;
    }

}

void test(){
    deque<int> d1;
    for (int i = 0; i < 10; ++i) {
        d1.push_back(i+1);
        // 尾部插入
        d1.push_front(i+1);
        // 头部插入
    }
    printDeque(d1);


    deque<int> d2(10,100);
    printDeque(d2);

    
}

int main() {

    test();

    return 0;
}

2. deque 赋值操作

deque& operator=(const deque &deq); // 重载等号操作符
assign(beg,end); // 将(beg,end)区间中的数据拷贝赋值给本身
assign(n,elem); // 将n个elem拷贝赋值给本身

void test(){
    deque<int> d1;
    for (int i = 0; i < 10; ++i) {
        d1.push_front(i+1);
        // 头部插入
    }
    printDeque(d1);

    deque<int> d2 = d1;
    // 重载等号操作符
    printDeque(d2);

    deque<int> d3;
    d3.assign(d2.begin(),d2.end());
    // 将(beg,end)区间中的数据拷贝赋值给本身
    printDeque(d3);

    deque<int> d4;
    d4.assign(10,1);
    printDeque(d4);

}

在这里插入图片描述

3. deque 大小操作

deque.empty(); // 判断容器是否为空
deque.size(); // 返回容器中元素的个数
deque.resize(num); //重新指定容器的长度为num,若容器变长,则以默认值0重新填充位置;若容器变短,则末尾超出容器长度的元素被删除
deque.resize(num,elem); // 重新指定容器的长度为num,若容器变长,则以elem值填充新位置;若容器变短,则以末尾超出容器长度的元素被删除

void test(){
    deque<int> d1;
    for (int i = 0; i < 10; ++i) {
        d1.push_front(i+1);
        // 头部插入
    }
    printDeque(d1);

    cout << d1.empty() << endl;
    
    cout << d1.size() << endl;
    

    d1.resize(5);
    printDeque(d1);

    d1.resize(10);
    printDeque(d1);

    d1.resize(12,100);
    printDeque(d1);

}

在这里插入图片描述

4. deque 插入和删除
  • 两端插入和删除操作
    push_back(elem); // 在容器尾部插入一个数据
    push_front(elem); // 在容器头部插入一个数据
    pop_back(); // 删除容器最后一个数据
    pop_front(); // 删除容器第一个数据
  • 指定位置进行插入和删除操作
    insert(pos,elem); // 在pos位置插入一个elem元素的拷贝,返回新数据的位置
    insert(pos,n,elem); // 在pos位置插入n个elem数据,无返回值
    insert(pos,beg,end); // 在pos位置插入[beg,end)区间的数据,无返回值
    clear(); // 清空容器的所有数据
    erase(beg,end); // 删除[beg,end)区间的数据,返回下一个数据的位置
    erase(pos); // 删除pos位置的数据,返回下一个数据的位置
void test(){
    deque<int> d1;
    d1.push_back(1);
    // 在尾部插入一个元素
    d1.push_front(2);
    // 在头部插入一个元素
    printDeque(d1);

    d1.pop_back();
    // 删除尾部第一个元素
    printDeque(d1);


    d1.push_front(1);
    deque<int>::const_iterator it = d1.begin();
    it++;
    d1.insert(it,3);
    // 插入操作
    printDeque(d1);
    d1.insert(it,2,10);
    printDeque(d1);


    deque<int> d2;
    for (int i = 5; i < 10; ++i) {
        d2.push_front(i);
    }
    d1.insert(it,d2.begin(),d2.end());
    printDeque(d1);

    d1.erase(it);
    printDeque(d1);


}

在这里插入图片描述

5. deque 容器数据存取

at(index); // 返回索引idx所指的数据
operator[]; // 返回索引idx所指的数据
front(); // 返回容器中第一个数据元素
back(); // 返回容器中最后一个数据元素

void test(){
    deque<int> d1;
    for (int i = 0; i < 5; ++i) {
        d1.push_back(i+1);
    }
    printDeque(d1);

    for (int i = 0; i < d1.size(); ++i) {
        cout << d1[i] << ends;
    }
    cout << endl;
    for (int i = 0; i < d1.size(); ++i) {
        cout << d1.at(i) << ends;
    }
    cout << endl;
    cout << "第一个元素" << d1.front()<< endl;
    cout << "最后一个元素" << d1.back()<< endl;
}

在这里插入图片描述

6. deque 排序操作

需要导入头文件#include <algorithm>

sort(iterator beg,iterator end); // 对beg和end区间内元素进行排序

void test(){
    deque<int> d1;
    d1.push_back(3);
    d1.push_back(100);
    d1.push_back(2);
    printDeque(d1);

    sort(d1.begin(),d1.end());
    // 默认升序
    printDeque(d1);
}

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

⌈ 传知代码 ⌋ 深度知识追踪

&#x1f49b;前情提要&#x1f49b; 本文是传知代码平台中的相关前沿知识与技术的分享~ 接下来我们即将进入一个全新的空间&#xff0c;对技术有一个全新的视角~ 本文所涉及所有资源均在传知代码平台可获取 以下的内容一定会让你对AI 赋能时代有一个颠覆性的认识哦&#x…

Ruoyi5.x RuoYi-Vue-Plus新建Translation翻译类

若依框架&#xff08;RuoYi&#xff09;中的Translation翻译类主要作用在于实现字段值的转换或翻译功能&#xff0c;以提高数据展示的准确性和友好性。以下是其具体作用的一些关键点&#xff1a; 字段值转换&#xff1a;若依框架在处理数据时&#xff0c;有时需要将某些字段的…

【Linux多线程】线程的终止、等待和分离

文章目录 线程终止正常退出return 退出pthread_exit函数终止线程 pthread_cancel强制终止线程进程终止 线程等待为什么需要等待线程&#xff1f;pthread_join函数 分离线程pthread_detach函数 线程终止 下面给出终止线程的三种方式&#xff1a; 正常退出&#xff1a; 线程执行…

小冬瓜AIGC 手撕LLM 拼课

小冬瓜aigc手撕LLM学习 官方认证 手撕LLMRLHF速成班-(附赠LLM加速分布式训练超长文档&#xff09; 帮助多名同学上岸LLM方向&#xff0c;包括高校副教授&#xff0c;北美PhD&#xff0c;大厂等 课程名称【手撕LLMRLHF】 授课形式&#xff1a;在线会议直播讲解课后录播 时间&…

祝大家端午节安康

五月到端午&#xff0c;愿你端来快乐&#xff0c;无烦无恼&#xff1b;端来好运&#xff0c;无时无刻&#xff1b;端来健康&#xff0c;无忧无虑&#xff1b;端来财富&#xff0c;五谷丰登&#xff1b;端来祝福&#xff0c;五彩缤纷。端午节安康&#xff01;

记录一次被谷歌封号后又解封的过程

先提前恭祝2024年所有参加高考的学子们都能金榜题名&#xff0c;会的全对&#xff0c;不会的蒙的全对&#xff01; 一、背景 众所周知&#xff0c;谷歌、ios应用市场对app的审查都是极其严格的&#xff0c;开发者稍有不慎就会被谷歌下架应用&#xff0c;乃至封号。我们公司是做…

Linux:冯·诺依曼体系结构和操作系统

文章目录 冯诺依曼体系结构操作系统概念操作系统的作用定位机制操作系统如何管理硬件 冯诺依曼体系结构 我们常见的计算机&#xff0c;如笔记本。我们不常见的计算机&#xff0c;如服务器&#xff0c;大部分都遵守冯诺依曼体系。 截至目前&#xff0c;我们所认识的计算机&…

【Python】在【数据挖掘】与【机器学习】中的应用:从基础到【AI大模型】

目录 &#x1f497;一、Python在数据挖掘中的应用&#x1f495; &#x1f496;1.1 数据预处理&#x1f49e; &#x1f496;1.2 特征工程&#x1f495; &#x1f497;二、Python在机器学习中的应用&#x1f495; &#x1f496;2.1 监督学习&#x1f49e; &#x1f496;2.2…

高考分数查询结果自动推送至微信(卷II)

祝各位端午节安康&#xff01;只要心中无结&#xff0c;每天都是节&#xff0c;开心最重要&#xff01; 在上一篇文章高考分数查询结果自动推送至微信&#xff08;卷Ⅰ&#xff09;-CSDN博客中谈了思路&#xff0c;今天具体实现。文中将敏感信息已做处理&#xff0c;读者根据自…

6.全开源源码---小红书卡片-跳转微信-自动回复跳转卡片-商品卡片-发私信-发群聊-安全导流不封号-企业号白号都可以用

现在用我们的方法&#xff0c;可以规避违规风险&#xff0c;又可以丝滑引流&#xff0c;因为会以笔记的形式发给客户&#xff0c;点击之后直接跳微信&#xff0c;我们来看看演示效果吧&#xff08;没有风险提示&#xff09; 无论是引流还是销售产品都会事半功倍。

redis03 补充 redis驱动模型:事件驱动

1.文件事件 1.1 1.2 注&#xff1a; epoll是linux系统的底层IO多路复用技术 kqueue是mac的底层IO多路复用技术 在 Epoll 中&#xff0c;Epoll 就是事件通知器&#xff0c;可以向 Epoll 注册我们感兴趣的事件。 1.3 1.4 5. 5.1 5.2 5.35.4

onesixtyone一键扫描SNMP服务(KALI工具系列二十)

目录 1、KALI LINUX 简介 2、onesixtyone工具简介 3、在KALI中使用onesixtyone 3.1 目标主机IP&#xff08;win&#xff09; 3.2 KALI的IP 4、操作示例 4.1 扫描目标主机 4.2 加上团队名称 4.3 输出详细结果 4.4 扫描整个网段 5、总结 1、KALI LINUX 简介 Kali Lin…

ThinkPHP发邮件配置教程?群发功能安全吗?

ThinkPHP发邮件的注意事项&#xff1f;如何优化邮件发送的性能&#xff1f; 无论是用户注册、密码重置还是消息提醒&#xff0c;发送邮件都是一个常见的需求。AokSend将详细介绍如何在ThinkPHP框架中配置和发送邮件&#xff0c;帮助开发者轻松实现邮件功能。 ThinkPHP发邮件&…

Discuz! X3.4发帖时间修改插件批量操作版

下载地址&#xff1a;Discuz! X3.4发帖时间修改插件批量操作版 发帖时间与回复时间说明 1、使用本插件修改发帖时间&#xff0c;则帖子中的回复楼层的时间会保持同步同间隔修改&#xff0c;所谓同步同间隔就是如果某个回复是在主题发布之后一小时回复的&#xff0c;那么修改之…

MySQL—多表查询—练习(1)

一、引言 上几篇关于多表查询的基本几个部分全部学习完了。 多表查询的基本类型的查询包括以下&#xff1a; 1、内连接&#xff08;隐式内连接、显示内连接&#xff09;&#xff1a;... [INNER] JOIN ... ON 条件; &#xff09; 2、外连接&#xff08;左外连接、右外连接&…

[沉迷理论]进制链表树

往期文章推荐&#xff1a; 题解之最大子矩阵-CSDN博客 洛谷P1115最大子段和[神奇的题目]-CSDN博客 &#xff08;一条神奇的分割线&#xff09; 前言 好久没有更新的我总算在百忙之中抽出时间写了篇博客。 最近总算结束了动态规划的学习&#xff0c;真的是头昏脑涨啊。 最…

MySQl基础----Linux下搭建mysql软件及登录和基本使用(附实操图超简单一看就会)

绪论​ 涓滴之水可磨损大石&#xff0c;不是由于他力量强大&#xff0c;而是由于昼夜不舍地滴坠。 只有勤奋不懈地努力&#xff0c;才能够获得那些技巧。 ——贝多芬。新开MySQL篇章&#xff0c;本章非常基础包括如何在Linux上搭建&#xff08;当然上面的SQL语句你在其他能执行…

初阶 《分支和循环语句》 3.循环语句

3.循环语句 while for do while 3.1 while循环 前面已经掌握了 if 语句&#xff1a; if(条件)   语句; 当条件满足的情况下&#xff0c;if语句后的语句执行&#xff0c;否则不执行&#xff1b;但是这个语句只会执行一次。 由于我们发现生活中很多的实际的例子是&#xff1a;同…

MYSQL 索引下推 45讲

刘老师群里,看到一位小友 问<MYSQL 45讲>林晓斌的回答 大意是一个组合索引 (a,b,c) 条件 a > 5 and a <10 and b123, 这样的情况下是如何? 林老师给的回答是 A>5 ,然后下推B123 小友 问 "为什么不是先 进行范围查询,然后在索引下推 b123?" 然后就…

Leetcode 力扣114. 二叉树展开为链表 (抖音号:708231408)

给你二叉树的根结点 root &#xff0c;请你将它展开为一个单链表&#xff1a; 展开后的单链表应该同样使用 TreeNode &#xff0c;其中 right 子指针指向链表中下一个结点&#xff0c;而左子指针始终为 null 。展开后的单链表应该与二叉树 先序遍历 顺序相同。 示例 1&#xf…