list基础知识

server/2024/10/18 14:21:13/

list

1.list 的定义和结构

  • list 是双向链表,是C++的容器模板,其接收两个参数,即 list(a,b) 其中 a 表示指定容器中存储的数据类型,b 表示用于分配器内存的分配器类型,默认为 list <int>;

  • list 的特点:

    双向性:由于是双向链表,每个节点都包含前一个节点和后一个节点的指针,故此可以在 O(1) 内实现对某个元素的插入、删除,但对于访问读取来讲就需要 O(n) 的时间;

    动态大小:类似于 vector ,其大小也会随着需求扩展或收缩,无需提前定义容器的大小;

    不连续存储:list 的存储与数组不同,是离散的,节点之间的联系为双向的指针;

#include <iostream>
#include <list>
using namespace std;int main()
{list <int> mylist;mylist.push_back(1);mylist.push_back(2);mylist.push_back(3);mylist.push_front(0);	//可以双向访问故此可以使用push_front();for(auto num : mylist)cout << num << ' ';return 0;
}

    • list 为双向链表,插入删除的时间复杂度为 O(1) ,而访问和查找的操作的时间复杂度则为 O(n) 其中n为链表长度;

      如若需要大量进行访问查找的操作,则更加推荐使用 vector 或者 deque(双端队列,由vector实现)

2.list 的常用函数

1)push_back( ) 和 push_front( ) 用来向 list 的尾端或者首端插入一个元素;

2)pop_back() 和 pop_front() 用来去除 list 的尾端或者首端一个元素,在使用前要先判断 list 是否为空;

3)size() 返回 list 此时存有的元素个数;

4)empty( ) 用来检查 list 是否为空;

5)clear( ) 用来清空 list 的所有元素;

#include <iostream>
#include <list>
using namespace std;int main()
{list <int> mylist;mylist.push_back(1);mylist.push_back(2);mylist.push_back(3);mylist.push_front(0);for(auto num : mylist)cout << num << ' ';cout << '\n' << "第一个元素是:" << mylist.front(); return 0;
}

6)front( ) 和 back( ) 用来返回 list 里面第一个元素或最后一个元素的的引用

#include <iostream>
#include <list>
using namespace std;int main()
{list <int> mylist;mylist.push_back(1);mylist.push_back(2);mylist.push_back(3);mylist.push_front(0);mylist.front() ++;for(auto num : mylist)cout << num << ' ';cout << '\n' << "第一个元素是:" << mylist.front(); return 0;
}

7)begin() 和 end() 指向链表起始元素或者最后一个元素下一个位置的迭代器;

8)insert( ) 和 erase( ) 表示在指定位置之前插入或者移除一个或多个元素(需要逐个确认,故此为 O(n) 的时间复杂度);

#include <iostream>
#include <list>
using namespace std;int main()
{list <int> mylist;mylist.push_back(1);mylist.push_back(2);mylist.push_back(3);mylist.insert(++ mylist.begin(),0);	 //insert()是将第二个参数插入在在第一个参数指向位置的左侧mylist.erase(++ ++ mylist.begin(),-- mylist.end());//if(mylist.empty())	cout << "yes" << '\n';for(auto num : mylist)cout << num << ' ';return 0;
}

  • 这是最初始的 mylist.begin() 和 mylist.end() ;

  • 这是对迭代器进行 ++ 或者 -- 之后的 mylist.begin() 和 mylist.end()(只对mylist.begin() 和 mylist.end()左闭右开区间执行操作);

  • 注意:++迭代器才能改变进入函数的参数的大小


http://www.ppmy.cn/server/4645.html

相关文章

「 网络安全常用术语解读 」软件成分分析SCA详解:从发展背景到技术原理再到业界常用检测工具推荐

软件成分分析&#xff08;Software Composition Analysis&#xff0c;SCA&#xff09;是一种用于识别和分析软件内部组件及其关系的技术&#xff0c;旨在帮助开发人员更好地了解和管理其软件的构建过程&#xff0c;同时可帮助安全人员揭秘软件内部结构的神秘面纱。SCA技术的发展…

openssl3.2 - exp - 用base64后的字符串作为配置项的值

文章目录 openssl3.2 - exp - 用base64后的字符串作为配置项的值概述笔记配置项的值长度有限制 配置项的值不能是base64之后的直接值&#xff0c;需要处理之后才行。openssl配置项的值并不是所有可见字符都可以例子现在用的base64的类cipher_base64.hcipher_base64.cpp 现在用的…

wsl2 Ubuntu子系统内存只有一半的解决办法

物理机的内存是64G&#xff0c;在wsl2安装完Ubuntu20.04后&#xff0c;输入命令&#xff1a; free -g 发现只有32G&#xff0c;原因是默认只能获得物理机一半的内存&#xff1a; WSL 中的高级设置配置 | Microsoft Learn 因此可手动修改为与物理机同等大小&#xff1a; 1&a…

边缘计算【智能+安全检测】系列教程--使用OpenCV+GStreamer实现真正的硬解码,完全消除马赛克

通过现有博客的GST_URL = "rtspsrc location=rtsp://admin:abcd1234@192.168.1.64:554/h264/ch01/main/av_stream latency=150 ! rtph264depay ! avdec_h264 ! videorate ! videoconvert ! appsink sync=false" GStreamer的解码方式解码,大多情况应该存在上图马赛克…

MapReduce排序机制(Hadoop)

在MapReduce中&#xff0c;排序的目的是为了方便Reduce阶段的处理&#xff0c;通常是为了将相同键的键值对聚合在一起&#xff0c;以便进行聚合操作或其他处理。 1. Map阶段的局部排序&#xff08;Local Sorting&#xff09;&#xff1a; 对于MapTask&#xff0c;它会将处理的…

NX二次开发——矩形排料5(基于最低水平线+遗传算法排料策略实现)

目录 一、概述 二、知识回顾 2.1适应度函数的确定 2.2基因编码 2.3遗传算法复制&#xff08;选择&#xff09; 2.4遗传算法交叉操作 通过交叉操作可以增加种群个体的多样性&#xff0c;既可以产生更多的优秀解。下面通过顺序编码方法进行改进&#xff08;网上有很…

【Mysql】mysql表设计时字段类型的选择建议

目录 1. 整数类型 2. 小数类型 选择建议 例子 在 MySQL 中设计表时选择字段的数据类型&#xff0c;特别是当你知道该字段的值将仅包含数字时&#xff0c;你应根据数据的性质和范围来选择最适合的类型。以下是几种常见的数字类型及其适用场景&#xff1a; 1. 整数类型 TIN…

如何把npm切换成yarn管理项目

1.删掉项目中package-lock.json和依赖包 这一步手动删掉就好 2.全局安装yarn npm install -g yarn 3.可以开始执行yarn install安装依赖 1&#xff09;执行yarn init 这一步是修改npm生成的package.json文件&#xff0c;可能会遇到这个问题&#xff1a; 这个查了一下是有…