STL常见容器(list容器)---C++

STL常见容器目录:

  • 6.list容器
    • 6.1 list基本概念
    • 6.2 list构造函数
    • 6.3 list 赋值和交换
    • 6.4 list 大小操作
    • 6.5 list 插入和删除
    • 6.6 list 数据存取
    • 6.7 list 反转和排序
    • 6.8自定义排序案例

在这里插入图片描述

6.list容器

6.1 list基本概念

  • 功能: 将数据进行链式存储

  • 链表(list)是一种物理存储单元上非连续的存储结构,数据元素的逻辑顺序是通过链表中的指针链接实现的。

  • 链表的组成:链表由一系列结点组成

  • 结点的组成:一个是存储数据元素的数据域,另一个是存储下一个结点地址指针域

STL中的链表是一个双向循环链表.

在这里插入图片描述

如图,结点中的指针域包含两个指针(prev、next),其中prev指针指向前一个数据地址,next指针指向后一个结点中的数据——双向

对于第一个结点中的prev指针指向最后一个结点的数据,而最后一个结点中next指针指向第一个结点的数据——循环

由于链表的存储方式并不是连续的内存空间,因此链表list中的迭代器只支持前移和后移,(不可跳跃式访问,即非随机迭代器)属于双向迭代器

list的优点:

  • 采用动态存储分配,不会造成内存浪费和溢出;
  • 链表执行插入和删除操作十分方便,修改指针即可,不需要移动大量元素。

list的缺点:

  • 链表灵活,但是空间(指针域) 和 时间(遍历)额外耗费较大。(遍历时间多,空间占用大)

List有一个重要的性质,插入操作和删除操作都不会造成原有list迭代器的失效(除非将迭代器所在的结点删除),这在vector是不成立的(即在vector容器中当要添加的内容大小大于剩余空间,会重新开辟空间,故迭代器的位置将改变)

总结:STL中List和vector是两个最常被使用的容器,各有优缺点

6.2 list构造函数

功能描述:

  • 创建list容器

函数原型:

  • list<T> lst; //list采用采用模板类实现,对象的默认构造形式:
  • list(beg,end); //构造函数将[beg, end)区间中的元素拷贝给本身。
  • list(n,elem); //构造函数将n个elem拷贝给本身。
  • list(const list &lst); //拷贝构造函数。

同之间的几个容器

6.3 list 赋值和交换

功能描述:

  • 给list容器进行赋值,以及交换list容器

函数原型:

  • assign(beg, end); //将[beg, end)区间中的数据拷贝赋值给本身。
  • assign(n, elem); //将n个elem拷贝赋值给本身。
  • list& operator=(const list &lst); //重载等号操作符
  • swap(lst); //将lst与本身的元素互换。

6.4 list 大小操作

功能描述:

  • 对list容器的大小进行操作

函数原型:

  • size(); //返回容器中元素的个数

  • empty(); //判断容器是否为空

  • resize(num);

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

    • //重新指定容器的长度为num,若容器变长,则以elem值填充新位置。
    • //如果容器变短,则末尾超出容器长度的元素被删除。

6.5 list 插入和删除

功能描述:

  • 对list容器进行数据的插入和删除

函数原型:

  • push_back(elem);//在容器尾部加入一个元素
  • pop_back();//删除容器中最后一个元素
  • push_front(elem);//在容器开头插入一个元素
  • 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位置的数据,返回下一个数据的位置。
  • remove(elem);//删除容器中所有与elem值匹配的元素。

示例:

#include <list>void printlist(list<int>& L)
{for (list<int>::iterator it = L.begin(); it != L.end(); it++){cout << *it << " ";}cout << endl;
}
#include <list>
void test01()
{list<int> L;L.push_back(100);L.push_back(99);L.push_back(77);L.push_front(88);L.push_front(77);L.push_front(99);printlist(L);L.remove(99);//将99全部删除printlist(L);

输出:

99 77 88 100 99 77
77 88 100 77

总结

  • 尾插 — push_back
  • 尾删 — pop_back
  • 头插 — push_front
  • 头删 — pop_front
  • 插入 — insert
  • 删除 — erase
  • 移除 — remove
  • 清空 — clear

6.6 list 数据存取

功能描述:

  • 对list容器中数据进行存取

函数原型:

  • front(); //返回第一个元素。
  • back(); //返回最后一个元素。

在这里插入图片描述
在这里插入图片描述
注:所有不支持随机访问迭代器的容器,不可以使用标准算法,其内部会提供对于算法。

总结:

  • list容器中不可以通过[]或者at方式访问数据
  • 返回第一个元素 — front
  • 返回最后一个元素 — back

6.7 list 反转和排序

功能描述:

  • 将容器中的元素反转,以及将容器中的数据进行排序

函数原型:

  • reverse(); //反转链表
  • sort(); //链表排序

示例:

#include <list>void printlist(list<int>& L)
{for (list<int>::iterator it = L.begin(); it != L.end(); it++){cout << *it << " ";}cout << endl;
}
bool myCompare(int v1,int v2) //仿函数或回调函数
{return v1 > v2;
}
void test01()
{list<int> L;L.push_back(100);L.push_back(99);L.push_back(77);L.push_front(88);L.push_front(77);L.push_front(99);printlist(L);//反转容器的元素L.reverse();cout << "反转后:" << endl;printlist(L);//排序cout << "默认排序后:" << endl;L.sort(); //默认的排序规则 从小到大printlist(L);cout << "自定义降序排序后:" << endl;L.sort(myCompare); //指定规则,从大到小printlist(L);}

输出:

99 77 88 100 99 77
反转后:
77 99 100 88 77 99
默认排序后:
77 77 88 99 99 100
自定义降序排序后:
100 99 99 88 77 77

总结:

  • 反转 — reverse
  • 排序 — sort (成员函数)

6.8自定义排序案例

案例描述: 将Person自定义数据类型进行排序,Person中属性有姓名、年龄、身高、体重;

排序规则:按照年龄进行升序,如果年龄相同按照身高进行降序,如果身高相同按照体重升序

示例:

#include <list>
#include <string>
class Person {
public:Person(string name, int age, int height,int weight) {m_Name = name;m_Age = age;m_Height = height;m_Weight = weight;}public:string m_Name;  //姓名int m_Age;      //年龄int m_Height;   //身高int m_Weight;   //体重
};//仿函数或回调函数
bool ComparePerson(Person& p1, Person& p2) {if (p1.m_Age == p2.m_Age){if (p1.m_Height == p2.m_Height ){return p1.m_Weight < p2.m_Weight;}elsereturn p1.m_Height > p2.m_Height;}else{return p1.m_Age < p2.m_Age;}
}void PrintPerson(list<Person>&L)
{for (list<Person>::iterator it = L.begin(); it != L.end(); it++) {cout << "姓名: " << it->m_Name << " 年龄: " << it->m_Age<< " 身高: " << it->m_Height<<" 体重:"<<it->m_Weight << endl;}
}
void test01() {list<Person> L;Person p1("刘备", 35, 175,100);Person p2("曹操", 45, 180,80);Person p3("孙权", 40, 170,73);Person p4("赵云", 25, 190,80);Person p5("张飞", 35, 175,85);Person p6("关羽", 35, 170,84);L.push_back(p1);L.push_back(p2);L.push_back(p3);L.push_back(p4);L.push_back(p5);L.push_back(p6);PrintPerson(L);cout << "---------------------------------" << endl;L.sort(ComparePerson); //排序cout << "排序后:" << endl;PrintPerson(L);
}

输出:

姓名: 刘备 年龄: 35 身高: 175 体重:100
姓名: 曹操 年龄: 45 身高: 180 体重:80
姓名: 孙权 年龄: 40 身高: 170 体重:73
姓名: 赵云 年龄: 25 身高: 190 体重:80
姓名: 张飞 年龄: 35 身高: 175 体重:85
姓名: 关羽 年龄: 35 身高: 170 体重:84


排序后:
姓名: 赵云 年龄: 25 身高: 190 体重:80
姓名: 张飞 年龄: 35 身高: 175 体重:85
姓名: 刘备 年龄: 35 身高: 175 体重:100
姓名: 关羽 年龄: 35 身高:170 体重:84
姓名: 孙权 年龄: 40 身高: 170 体重:73
姓名: 曹操 年龄: 45 身高: 180 体重:80

总结:

  • 对于自定义数据类型,必须要指定排序规则,否则编译器不知道如何进行排序;
  • 高级排序只是在排序规则上再进行一次逻辑规则制定,并不复杂.

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

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

相关文章

Flutter输入框换行后自适应高度

Flutter输入框换行后输入框高度随之增加 效果 设计思想 通过TextEditingController在build中监听输入框&#xff0c;输入内容后计算输入框高度然后自定义适合的值&#xff0c;并且改变外部容器高度达到自适应高度的目的 参考代码 //以下代码中的值只适用于案例&#xff0c;…

MyBatis 学习(一)之 MyBatis 概述

目录 1 MyBatis 介绍 2 MyBatis 的重要组件 3 MyBatis 执行流程 4 参考文档 1 MyBatis 介绍 MyBatis 是一个半自动化的 ORM &#xff08;Object-Relational Mapping&#xff0c;对象关系映射&#xff09;持久层框架&#xff0c;它允许开发者通过 XML 或注解将对象与数据库中…

docker的简介--安装--操作命令

1.docker的简介 1.1docker是什么 用一句话来说docker就是一个新一代虚拟化技术 Docker是一种开源的平台&#xff0c;用于开发、交付和运行应用程序。它允许开发人员将应用程序和它们的依赖打包在一个容器中&#xff0c;然后部署到任何支持Docker的环境中。Docker的主要特点包括…

【React架构 - Scheduler中的MessageChannel】

前序 我们都知道JS代码是在浏览器5个进程(下面有介绍)中渲染进程中的Js引擎线程执行的&#xff0c;其他还有GUI渲染线程、定时器线程等&#xff0c;而页面的布局和绘制是在GUI线程中完成的&#xff0c;这些线程之间是互斥的&#xff0c;所以在执行Js的同时会阻塞页面的渲染绘制…

android应用开发基础知识,安卓面试2020

第一章&#xff1a;设计思想与代码质量优化 1、设计思想六大原则 2、三大设计模式 3、数据结构 4、算法 第二章&#xff1a;程序性能优化 1、启动速度和执行效率优化 2、布局检测与优化 3、内存优化 4、耗电优化 5、网络传输与数据存储优化 6、APK大小优化 7、屏幕适配 8、…

用Java语言创建的Spring Boot项目中,如何传递List集合呢?

前言&#xff1a; 在上篇文章中&#xff0c;用Java语言创建的Spring Boot项目中&#xff0c;如何传递数组呢&#xff1f;&#xff1f;-CSDN博客&#xff0c;我们了解到Spring Boot项目中如何传递数组&#xff0c;但是&#xff0c;对于同类型的List集合&#xff0c;我们又该如何…

Centos7:自动化配置vim | suoders信任列表添加普通用户

Centos7&#xff1a;自动化配置vim | suoders信任列表添加普通用户 vim 配置原理sudoers系统可信任列表中添加普通用户自动化配置vim vim 配置原理 在目录/etc下有一个vimrc文件&#xff0c;该文件是系统中公共的vim配置文件&#xff0c;对所有用户都成立。  而在每个普通用户…

【Kafka系列 06】Kafka Producer源码解析

温馨提示&#xff1a;本文基于 Kafka 2.3.1 版本。 一、Kafka Producer 原理图 生产者的 API 使用还是比较简单&#xff0c;创建一个 ProducerRecord 对象&#xff08;这个对象包含目标主题和要发送的内容&#xff0c;当然还可以指定键以及分区&#xff09;&#xff0c;然后调…

poi 设置允许西文在单词中间换行

说明本文是CSDN-问答模块,题主提问。问题描述:poi 设置允许西文在单词中间换行 一、问题描述 poi 设置允许西文在单词中间换行? // 创建一个新的文档XWPFDocument document = new XWPFDocument();// 创建段落XWPFParagraph firstParagraph = document.createParagraph();fir…

2022《OpenScene: 3D Scene Understanding with Open Vocabularies》阅读笔记2

A. Implementation Details 3D Distillation. 我们基于PyTorch实现。为了提取,我们使用Adam[26]作为优化器,初始学习率为1e−4,并训练100个epochs。对于MinkowskiNet,我们对ScanNet和Matterport3D实验使用2cm的体素大小,对nuScenes使用5cm的体素尺寸。对于室内数据集,我…

RTSPServer推流服务

RTSPServer推流服务 1.开发原因 由于项目需要使用&#xff0c;虽然有现成的RTSPServer推流服务&#xff0c;由于是闭源代码&#xff0c;无法查看了解内部的逻辑处理流程&#xff0c;所以急需要一套较为稳定并可以使用的推流服务&#xff0c;并且从网上看大部分的RTSPServer推流…

IntelliJ IDEA 常用快捷键和下载链接

下载链接&#xff08;windows&#xff09; 下载 IntelliJ IDEA – 领先的 Java 和 Kotlin IDE 编码时&#xff1a; 跳转到引用方法的地方 &#xff08;有多个引用时会出现下拉列表&#xff09; ctrl鼠标左键 跳转后回到原来的地方 …

LeetCode 2120.执行所有后缀指令

现有一个 n x n 大小的网格&#xff0c;左上角单元格坐标 (0, 0) &#xff0c;右下角单元格坐标 (n - 1, n - 1) 。给你整数 n 和一个整数数组 startPos &#xff0c;其中 startPos [startrow, startcol] 表示机器人最开始在坐标为 (startrow, startcol) 的单元格上。 另给你…

后端程序员入门react笔记(六)- 讲透Promise与Fetch

js声明变量的三种方式 我们通常使用 var let 和const来声明js的变量&#xff0c;但是这三者有什么区别呢&#xff1f; var的变量可以是全局的或者函数作用域&#xff0c;而let和const只能是块级作用域var和let可以重新赋值&#xff0c;而const是不允许重新赋值的&#xff0c;…

【王道数据结构】【chapter7查找】【P285t5】

线性表中各节点的检索概率不等时&#xff0c;可用如下策略提高顺序检索的效率&#xff1b;若找到指定的结点&#xff0c;则将该结点和其前驱结点&#xff08;若存在&#xff09;交换&#xff0c;使得经常被访问的结点尽量位于表的前端。试设计在顺序结构和链式结构的线性表盘上…

python中集合(Set)和列表(List)性能比较

文章目录 引言1. Set和List2. 性能对比3. 总结 引言 在当今的软件开发过程中&#xff0c;Python 已经成为了一种极为流行的编程语言&#xff0c;得益于其简洁的语法和强大的库支持。在 Python 中&#xff0c;列表&#xff08;List&#xff09;和集合&#xff08;Set&#xff0…

敏捷开发中如何写好用户故事?

什么是用户故事&#xff1f; 用户故事&#xff08;user story&#xff09;是一个用来确认用户和用户需求的简短描述&#xff0c;作为什么用户&#xff0c;希望如何&#xff0c;这样做的目的或者价值何在。用户故事在软件研发中又被描述为需求。用户故事通常的格式为&#xff1…

STL容器之list

​ 1.封装除了对数据的保护、更好地管理数据之外&#xff0c;还有实现了对上层的统一&#xff1b; ​ 2.类模板参数的不同&#xff0c;一方面是为了实例化出来不同的类&#xff0c;另一方面是为了实现类的成员函数的不同&#xff1b; 一、认识list ​ 1.list是一种带头双向循…

java高并发场景面试题,干货来袭

为什么阿里巴巴的持久层抛弃hibernate&#xff0c;采用MyBatis框架&#xff1f; 原因大概有以下4点&#xff1a; 尤其是需要处理大量数据或者大并发情况的网站服务&#xff0c;这也阿里选择MyBatis的原因。 MyBatis整体架构 不多讲&#xff0c;先看目录图 MyBatis源码笔记文档…

捕获在野SMBGhost本地提权攻击样本

前言 从Windows10 v1903/Windows Server v1903开始&#xff0c;微软在协议SMB3.1.1中开启了对数据压缩传输的支持&#xff0c;但是由于SMB没有正确处理压缩的数据包&#xff0c;在客户端/服务端解压数据的时候&#xff0c;没有对COMPRESSIN_TRANSFORM_HEADE结构进行安全校验&a…