C++容器:list(双向链表)

news2024/9/20 18:35:58

一丶list介绍

C++中的list容器底层确实是以双向链表的形式实现的

  list容器是C++标准模板库(STL)中的一部分,它提供了对列表数据结构的实现。

  • 双向链表结构list容器的每个元素都是通过指针链接在一起的,每个元素都包含指向前一个和后一个元素的指针。这种双向链表的结构使得在list容器中插入和删除元素时无需移动其他元素,因此这些操作的时间复杂度为O(1)。
  • 内存分配:由于list容器基于双向链表,其元素可以分散存储在内存中,不需要像数组或vector那样连续分配内存空间。这使得list在内存使用上更加灵活,特别适合于需要频繁插入和删除操作的场景。
  • 迭代器稳定性list容器的迭代器在插入和删除操作中保持稳定性,即使在进行这些操作时,指向其他元素的迭代器也不会失效。

二丶list的使用

       C++中list容器提供了多种用于操作列表的函数,使得对元素的插入、删除和访问变得灵活而高效。以下是一些常用的list容器函数:

  • push_back():在列表的尾部插入一个新元素。
  • push_front():在列表的头部插入一个新元素。
  • pop_back():删除列表尾部的元素。
  • pop_front():删除列表头部的元素。
  • size():返回列表中元素的个数。
  • empty():判断列表是否为空,如果为空则返回true,否则返回false。
  • clear():清除列表中的所有元素。
  • erase():删除列表中的一个或多个元素。
  • remove():移除列表中所有等于特定值的元素。
  • sort():对列表中的元素进行排序。
  • reverse():反转列表中元素的顺序。
#include<iostream>
#include<list>
using namespace std;
template<class T>
void PrintList(const list<T>& l)  //打印函数
{
	auto it = l.begin();
	while (it != l.end())
	{
		cout << *it << " ";
		it++;
	}
	cout << endl;
}
void ListTest()
{
	list<int> l;    //空
	l.push_back(1);   //尾插
	l.push_back(2);
	l.push_back(3);
	PrintList(l);


	list<int> _l(l);  //构造函数重载
	PrintList(_l);
	_l.clear();


	l.push_front(4);  //头插
	l.push_front(5);
	l.push_front(6);
	PrintList(l);


	l.sort();   //排序
	PrintList(l);


	l.pop_back();  //尾删
	l.pop_back();
	PrintList(l);


	l.pop_front();  //头删
	l.pop_front();
	PrintList(l);
}
int main()
{
	ListTest();
	return 0;
}

 

        这些用法其实很简单,主要还是要学会灵活使用。这里要注意一下sort函数,默认是升序函数

底层使用的一般是快速排序算法,然后sort重载了另一个函数,这里的Compare 是用来控制升序或者降序的,称为仿函数

std::list::sort

(1)	
  void sort();

(2)	
template <class Compare>
  void sort (Compare comp);

      如下,MyCompare 只重载了运算符(),然后我们自己写了一个sort,调用的是std::sort,std::sort(迭代器1,迭代器2,仿函数),不传仿函数就调用另一个重载函数将迭代器范围内升序排序

struct MyCompare {
    bool operator()(int a, int b) {
        return a > b; // 降序排列
    }
};

template <class ForwardIt, class Compare>
void sort(ForwardIt first, ForwardIt last, Compare comp) {
    // ... 其他代码 ...

    while (first != last) {
        // ... 其他代码 ...

        // 使用comp比较函数对象比较两个元素
        if (comp(*i, *j)) {
            // ... 其他代码 ...
        } else {
            // ... 其他代码 ...
        }

        // ... 其他代码 ...
    }

    // ... 其他代码 ...
}

三丶与vector比较

  1. 内存分配:

    • vector:在内存中连续存储元素,当需要添加或删除元素时,可能会导致整个容器的内存重新分配。
    • list:在内存中非连续存储元素,每个元素都是一个单独的节点,包含数据和指向前后节点的指针。因此,添加或删除元素时,只需要修改相邻节点的指针,不会影响其他元素的内存位置。
  2. 访问方式:

    • vector:支持随机访问,可以直接通过索引访问任何元素,访问速度快。
    • list:不支持随机访问,只能通过迭代器进行顺序访问。
  3. 插入和删除操作:

    • vector:在尾部插入和删除元素的效率高,因为不需要移动其他元素;而在中间或头部插入和删除元素效率较低,因为需要移动其他元素。
    • list:在任何位置插入和删除元素的效率都较高,因为只需要修改相邻节点的指针。
  4. 容量和大小:

    • vector:有固定的容量,可以容纳的元素数量有限。当超过容量时,会自动扩容,可能会引起内存重新分配和元素移动。
    • list:没有固定容量的概念,只要内存允许,可以不断地添加新元素。
  5. 性能:

    • vector:在内存中连续存储,有利于缓存的利用,因此访问速度较快。但在插入和删除操作时可能需要移动大量元素,效率较低。
    • list:在内存中非连续存储,不利于缓存的利用,访问速度较慢。但在插入和删除操作时只需要修改指针,效率较高。

    总之,vectorlist各有优缺点,具体使用哪个容器取决于具体的应用场景和需求。如果需要频繁访问元素,可以选择vector;如果需要频繁插入和删除元素,可以选择list

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

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

相关文章

C++11 新特性 常量表达式 constexpr

为了解决常量无法确定的问题&#xff0c;C11在新标准中提出了关键字constexpr&#xff0c;它能够有效地定义常量表达式&#xff0c;并且达到类型安全、可移植、方便库和嵌入式系统开发的目的。 一、常量的不确定性 在C11标准以前&#xff0c;我们没有一种方法能够有效地要求一…

为什么Python中会有集合set类型?

知乎上有人提问&#xff0c;为什么Python有了列表list、元组tuple、字典dict这样的容器后&#xff0c;还要弄个集合set&#xff1f; 确实set和list、tuple、dict一样&#xff0c;都是python的主要数据类型&#xff0c;它们的作用是不同的。 因为set是数学意义上的集合&#xf…

战网国际服加速器用哪个好 暴雪战网好用加速器介绍

战网国际版&#xff0c;又称Battle.net环球版&#xff0c;是暴雪娱乐操盘的全球性游戏互动平台&#xff0c;它跨越地理界限&#xff0c;服务于全球游戏爱好者。与地区限定版本相异&#xff0c;国际版赋予玩家自由进入暴雪旗下众多经典游戏的权利&#xff0c;无论身处何方&#…

使用C++实时读取串口数据(window使用已编译LibModbus库并用QT实现一个实时读取串口数据)

Modbus协议简介&#xff1a; 在工业自动化领域&#xff0c;Modbus协议是一个应用层通讯协议&#xff0c;它为电子设备之间的通信提供了一个常用的标准方法。Modbus协议最初由Modicon公司&#xff08;现为施耐德电气的一部分&#xff09;在1979年发明用于其可编程逻辑控制器&…

AIGC行业现在适合进入吗

AIGC行业目前正处于快速发展阶段,市场需求正处于爆发期,上大学网&#xff08;www.sdaxue.com&#xff09;认为&#xff0c;对于有兴趣的个人或企业而言&#xff0c;现在可能是一个适合进入的时机&#xff0c;以下是具体的分析&#xff0c;供大家参考&#xff01; 一、AIGC行业前…

java医院信息系统HIS源码SaaS模式Java版云HIS系统 接口技术RESTful API + WebSocket + WebService

java医院信息系统HIS源码SaaS模式Java版云HIS系统 接口技术RESTful API WebSocket WebService 云HIS是基于云计算的医疗卫生信息系统&#xff08;Cloud-Based Healthcare Information System&#xff09;&#xff0c;它运用云计算、大数据、物联网等新兴信息技术&#xff0c;…

熬了快两个月,终于拿到了淘天后端offer!

今年的暑期实习挺难找的&#xff0c;很多同学忙了几个月到现在还没有一个offer&#xff0c;真的很常见&#xff01;没找到暑期实习的同学千万不要太焦虑&#xff0c;可以留意留意日常实习&#xff0c;日常实习也找不到&#xff0c;那就去完善自己的项目经历&#xff0c;认真准备…

软件工程期末复习(8)需求的表达方法和状态转换图

需求的表达方法 系统模型 需求分析的任务就是借助于当前系统的逻辑模型导出目标系统的逻辑模型&#xff0c;解决目标系统 “做什么” 的问题 通常软件开发项目是要实现目标系统的物理模型。目标系统的具体物理模型是由它的逻辑模型经实例化&#xff0c;即具体到某个业务领域而…

苹果电脑里面的资料为什么不能拷贝到硬盘 mac硬盘权限限制怎么解决 mac东西拷不进硬盘怎么办

你在使用Mac电脑的时候有没有遇到过文件无法拷贝的情况呢&#xff1f;这种情况多见于Mac电脑使用U盘或者移动硬盘的时候&#xff0c;不少用户都发现&#xff1a;可以正常读取U盘里的数据但是无法拷贝文件进去&#xff0c;为什么会有这种情况呢&#xff1f; 一、mac东西拷不进硬…

macbook同时配置github,gitlab,gitee

背景&#xff1a;我的本地环境之前已经配置了github与gitlab的共存&#xff0c;现在想要添加一个gitee的项目&#xff0c;我的全局的账号和邮箱配置已经配置为了gitlab的账号邮箱&#xff0c;下边新增gitee的配置时没有对这一块儿的变更。新增了gitee后&#xff0c;我也对gitla…

webpack优化构建速度示例-IgnorePlugin:

IgnorePlugin是webpack的一个内置插件&#xff0c;允许你忽略某些特定的模块或文件 webpack.config.jsconst config {entry: ./src/index.js,output: {filename: main.js},mode: development, }module.exports config;src/index.js import moment from moment console.log(mo…

汽车工厂安灯系统能够快速知晓生产现场的状况

汽车工厂是一个庞大的生产系统&#xff0c;其中有数以百计的工人、机器和设备在不断运转&#xff0c;以确保汽车的生产顺利进行。在如此复杂的生产环境中&#xff0c;安全是至关重要的&#xff0c;而安灯系统正是一个能够帮助汽车工厂快速知晓生产现场状况的重要工具。 安灯系统…

程序在银河麒麟系统下实现开机自启及创建桌面快捷方式

目录 1. 机器环境说明 2. 程序开机自启动设置 2.桌面快捷方式设置 3. 附加说明 1. 机器环境说明 机器安装的银河麒麟操作系统属性如下&#xff1a; 2. 程序开机自启动设置 第1步&#xff1a;编写一个脚本,用于自动化启动&#xff0c;为便于后文描述&#xff0c;该脚本名称…

84.网络游戏逆向分析与漏洞攻防-游戏技能系统分析-筛选与技能有关的数据包

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 如果看不懂、不知道现在做的什么&#xff0c;那就跟着做完看效果&#xff0c;代码看不懂是正常的&#xff0c;只要会抄就行&#xff0c;抄着抄着就能懂了 内容…

失业焦虑如何缓解心情?流静冥想

失业焦虑如何缓解心情&#xff1f;人生旅途&#xff0c;失业犹如山重水复&#xff0c;焦虑似迷雾遮望眼。古语云&#xff1a;“山不厌高&#xff0c;海不厌深。”心之向往&#xff0c;冥想便是那披荆斩棘之斧&#xff0c;如何带你走出困境&#xff1f; “静以修身”&#xff0c…

IT行业的革新力量:技术进步与未来展望

在当今时代&#xff0c;信息技术&#xff08;IT&#xff09;行业无疑是全球经济的重要推动力之一。随着数字化转型的不断深入&#xff0c;IT行业的边界正在扩大&#xff0c;它不仅包括传统的软硬件开发、网络建设和运维服务&#xff0c;还涵盖了云计算、大数据、人工智能&#…

文件系统和软硬连接

一、磁盘 磁盘可以存储大量的二进制数据&#xff0c;并且断电后也能保持数据不丢失。因此磁盘是一种永久性存储介质&#xff0c;在计算机中&#xff0c;磁盘是一个外设&#xff0c;也是唯一的机械设备。既然磁盘是一个外设&#xff0c;那么就意味着&#xff0c;磁盘和内存&…

时间序列预测:探索性数据分析和特征工程的实用指南

时间序列分析是数据科学和机器学习领域最广泛的主题之一:无论是预测金融事件、能源消耗、产品销售还是股票市场趋势&#xff0c;这一领域一直是企业非常感兴趣的领域。 随着机器学习模型的不断进步&#xff0c;使除了传统的统计预测方法(如回归模型、ARIMA模型、指数平滑)外&a…

C++语法|对象的浅拷贝和深拷贝

背景&#xff1a; 我们手写一个顺序栈&#xff0c;展开接下来的实验&#xff1a; ⭐️ this指针指向的是类在内存中的起始位置 class SeqStack { public:SqeStack(int size 10) {cout << this << "SeqStack()" << endl;pstack_ new int[size_];t…

APP封装后防止破解的全方位策略

移动应用开发完成后&#xff0c;封装&#xff08;编译打包&#xff09;是发布前的重要步骤。然而&#xff0c;一旦APP发布&#xff0c;就可能面临被逆向工程破解的风险&#xff0c;从而导致源代码泄露、数据被盗取等严重后果。 本文将介绍一系列实用的策略和技术&#xff0c;帮…