【C++】:STL详解 —— list类

目录

list的概念

list的构造函数 

list的大小

size()

resize()

empty()

list的插入

push_front()和emplace_front()

push_back()和emplace_back()

insert()和emplace()

list的删除

pop_front()

pop_back()

erase()

remove() 

remove_if()  

 unique()  

clear()

list的拼接

splice()

merge()

list的迭代器

迭代器类型

begin()和end()

rbegin()和rend()

list中的元素访问

front()

back()

list的逆置


list的概念

  1. list是一种可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代。
  2. list的底层是双向链表结构,双向链表中每个元素存储在互不相关的独立结点当中,在结点中通过指针指向其前一个元素和后一个元素。
  3. list与forward_list非常相似,最主要的不同在于forward_list是单链表,只能进行单方向迭代。
  4. list与其他容器相比,list通常在任意位置进行插入、删除元素的执行效率更高。
  5. list 和 forward_list最大的缺陷是不支持在任意位置的随机访问,其次,list还需要一些额外的空间,以保存每个结点之间的关联信息(对于存储的类型较小元素来说这可能是一个重要的因素)。

list的构造函数 

默认构造函数:创建一个空链表

list<T> list_name;

填充构造函数:创建包含 n 个相同值的链表

list<int> list2(5, 10);  // 包含5个值为10的节点:{10, 10, 10, 10, 10}

范围构造函数:通过迭代器范围 [first, last) 初始化链表

int arr[] = {1, 2, 3};
list<int> list3(arr, arr + 3);  // 复制数组内容:{1, 2, 3}

拷贝构造函数:通过另一个链表深拷贝初始化

list<int> list4(list3);  // 拷贝 list3 的内容:{1, 2, 3}

移动构造函数:通过移动另一个链表的资源初始化(高效转移所有权)

list<int> list5(move(list4));  // list4 变为空,list5 接管其内容

初始化列表构造函数(C++11 起):通过初始化列表直接赋值

list<int> list6 = {4, 5, 6};  // 直接初始化:{4, 5, 6}

 

list的大小

size()

  • size():返回当前元素数量
#include <list>
#include <iostream>int main() {list<int> mylist = {1, 2, 3, 4, 5};cout << "Size: " << mylist.size(); // 输出 5return 0;
}

resize()

  • 若 n < size():截断链表,仅保留前 n 个元素。

  • 若 n > size():扩展链表,新增元素默认初始化为 T()(或指定 value)。

std::list<int> mylist = {1, 2, 3};mylist.resize(5);     // 扩展为 {1, 2, 3, 0, 0}(填充默认值0)
mylist.resize(2);     // 截断为 {1, 2}
mylist.resize(4, 99); // 扩展为 {1, 2, 99, 99}

empty()

检查链表是否为空(等价于 size() == 0

std::list<int> mylist;
if (mylist.empty()) 
{std::cout << "List is empty!";
}

list的插入

push_front()和emplace_front()

  • push_front (const value_type& val)
    • ​​​在头部插入元素(拷贝构造)。
  • emplace_front (Args&&... args);(C++11 起)
    •  在头部直接构造元素(避免临时对象拷贝)

头部插入

list<int> mylist;
mylist.push_front(10);  // 链表内容:{10}
mylist.push_front(20);  // 链表内容:{20, 10}

push_back()和emplace_back()

尾部插入

  • push_front (const value_type& val)
    • ​​​在尾部插入元素(拷贝构造)。
  • emplace_front (Args&&... args);(C++11 起)
    •  在尾部直接构造元素(避免临时对象拷贝)
mylist.push_back(30);   // 链表内容:{20, 10, 30}

insert()和emplace()

  • insert(iterator pos, const T& value)  
    • 在迭代器 pos 指向的位置前插入元素(拷贝构造)。
  • emplace(iterator pos, Args&&... args)(C++11 起)
    • 在 pos 位置直接构造元素(更高效)。 

指定位置插入

示例一:插入单个元素

list<int> mylist = { 1, 2, 3 };
mulist.insert(mylist.begin(), 1);
// mylist { 1, 1, 2, 3 }

示例二:插入多个相同元素

list<int> mylist = { 1, 2, 3 };
list<int>::iterator it = mylist.begin();
myList.insert(it, 3, 100);     // 插入3个100
// mylist { 100, 100, 100, 1, 2, 3 }

示例三:插入范围元素

list<int> mylist = { 1, 2, 3 };
list<int>::iterator it = mylist.end();vector<int> vec = {5, 6, 7};
myList.insert(it, vec.begin(), vec.end());  // 在末尾插入vector内容
// mylist { 1, 2, 3, 4, 5, 6 }

list的删除

pop_front()

头部删除,移除链表第一个元素

list<int> mylist = { 1, 2, 3 };
mylist.pop_front();    // mylist:{ 2, 3 }

pop_back()

尾部删除,移除链表最后一个元素

list<int> mylist = { 1, 2, 3 };
mylist.pop_back();    // mylist:{ 1, 2 }

erase()

任意位置删除

erase(iterator pos)
删除迭代器 pos 指向的元素

list<int> mylist = {10, 20, 30, 40};auto it = mylist.begin() + 2;
mylist.erase(it);        // 删除30 → {10, 20, 40}

erase(iterator first, iterator last)
删除迭代器范围 [first, last) 内的元素(左闭右开)

list<int> mylist = {1, 2, 3, 4, 5};
auto it = mylist.erase(v.begin() + 1, v.begin() + 3); 
// 删除元素 2 和 3,v = {1, 4, 5}
// it 指向 4

remove() 

用于删除容器当中特定值的元素

list<int> list1 = { 1, 2, 3, 4,3, 3 };
lt.remove(3); //删除容器当中所有值为3的元素
// list1 { 1, 2, 4 }

remove_if()  

用于删除容器当中满足条件的元素。

bool single_digit(const int& val)
{return val < 10;
}list<int> list1 = { 1, 2, 3, 4,3, 3, 10 };
lt.remove_if(single_digit); / /删除容器当中值小于10的元素
// list1 { 10 }

 unique()  

用于删除容器当中连续的重复元素。 

list<int> list1 = { 1, 4 ,3 ,3, 2, 2, 3 };
list1.sort();     //将容器当中的元素排为升序
list1.unique();     //删除容器当中连续的重复元素
// list1 { 1, 2, 3, 4 }

clear()

移除所有元素,size() 变为 0

list<int> mylist = { 1, 2, 3 };
mylist.clear();    // mylist.size() == 0

list的拼接

splice()

可以将一个链表的元素移动到另一个链表中,无需复制元素。

示例一:合并整个链表

    list<int> list1 = {1, 2, 3};list<int> list2 = {4, 5, 6};// 将 list2 的所有元素移动到 list1 的末尾list1.splice(list1.end(), list2);// 输出结果: 1 2 3 4 5 6for (auto num : list1) {std::cout << num << " ";}

示例 2: 移动单个元素

list<int> list1 = {1, 2, 3};
list<int> list2 = {4, 5, 6};// 将 list2 的第一个元素移动到 list1 的末尾
auto it = list2.begin();
list1.splice(list1.end(), list2, it);    // list1{ 1, 2, 3 , 4 }

示例 3: 移动元素区间 

list<int> list1 = {1, 2, 3};
list<int> list2 = {4, 5, 6};// 将 list2 中从第二个元素到末尾的元素移动到 list1 的末尾
auto start = list2.begin();
start++;
auto end = list2.end();
list1.splice(list1.end(), list2, start, end);    
// list1 { 1, 2, 3, 5, 6 }

merge()

如果两个链表已排序,可以用 merge() 合并并保持有序:

std::list<int> list1 = {1, 3, 5};
std::list<int> list2 = {2, 4, 6};// 合并后 list2 变为空,list1 包含 1 2 3 4 5 6
list1.merge(list2);

list的迭代器

迭代器类型

迭代器类型说明示例
iterator可读写的正向迭代器list.begin()
const_iterator只读的正向迭代器list.cbegin()
reverse_iterator可读写的反向迭代器list.rbegin()
const_reverse_iterator只读的反向迭代器list.crbegin()

begin()和end()

  • begin():返回指向第一个元素的迭代器。

  • end():返回指向最后一个元素之后位置的迭代器(尾后迭代器)。

    list<int> lt(10, 2);//正向迭代器遍历容器list<int>::iterator it = lt.begin();while (it != lt.end()){cout << *it << " ";it++;}

rbegin()和rend()

  • rbegin():返回指向最后一个元素之后位置的迭代器(尾后迭代器)。

  • rend():返回指向第一个元素的迭代器。

    list<int> lt(10, 2);//反向迭代器遍历容器list<int>::reverse_iterator rit = lt.rbegin();while (rit != lt.rend()){cout << *rit << " ";rit++;}

支持的运算符

  • ++it 和 it++:向前移动

  • --it 和 it--:向后移动

  • *it:解引用获取元素值

  • it1 == it2 和 it1 != it2:比较是否指向同一位置

不支持的运算符

  • it + n 或 it[n](不支持随机访问)

  • it1 < it2(仅支持相等性比较)

 

list中的元素访问

front()

获取list容器第一个元素

    list<int> lt = { 0, 1, 2, 3, 4 };cout << lt.front() << endl; //0

back()

获取list容器最后一个元素

   list<int> lt = { 0, 1, 2, 3, 4 };cout << lt.back() << endl; //4

list的逆置

reverse()

list<int> list1 = { 1, 2, 3, 4, 5 };list1.reverse();
// list1 { 5, 4, 3, 2, 1 }  

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

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

相关文章

flex布局自定义一行几栏,靠左对齐===grid布局

模板 <div class"content"><div class"item">1222</div><div class"item">1222</div><div class"item">1222</div><div class"item">1222</div><div class"…

微软推出Office免费版,限制诸多,只能编辑不能保存到本地

易采游戏网2月25日独家消息&#xff1a;微软宣布推出一款免费的Office版本&#xff0c;允许用户进行基础文档编辑操作&#xff0c;但限制颇多&#xff0c;其中最引人关注的是用户无法将文件保存到本地。这一举措引发了广泛讨论&#xff0c;业界人士对其背后的商业策略和用户体验…

NLP的预处理数据

处理文本数据的主要工具是Tokenizer。Tokenizer根据一组规则将文本拆分为tokens。然后将这些tokens转换为数字&#xff0c;然后转换为张量&#xff0c;成为模型的输入。模型所需的任何附加输入都由Tokenizer添加。 如果您计划使用预训练模型&#xff0c;重要的是使用与之关联的…

应用的负载均衡

概述 负载均衡&#xff08;Load Balancing&#xff09; 调度后方的多台机器&#xff0c;以统一的接口对外提供服务&#xff0c;承担此职责的技术组件被称为“负载均衡”。 负载均衡器将传入的请求分发到应用服务器和数据库等计算资源。负载均衡是计算机网络中一种用于优化资源利…

C# 根据Ollama+DeepSeekR1开发本地AI辅助办公助手

在上一篇《访问DeepSeekR1本地部署API服务搭建自己的AI办公助手》中&#xff0c;我们通过通过Ollama提供的本地API接口用Python实现了一个简易的AI办公助手&#xff0c;但是需要运行Py脚本&#xff0c;还比较麻烦&#xff0c;下面我们用C#依据Ollama提供的API接口开发一个本地A…

springboot+dubbo+zookeeper的注册服务和调用实践

目录 zookeeper为什么可作为注册中心zookeeper注册中心优缺点启动zookeeper编写springboot项目提供dubbo服务1. 服务接口2. Springboot引入dubbo实现服务接口2.1 工程目录和依赖2.2 启动程序和application.properties2.3 DubboService 实现服务接口2.4 测试api&#xff0c;用于…

NL2SQL的应用-长上下文模型在处理NL2SQL任务时,相较于传统模型,有哪些显著的优势

大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下NL2SQL的应用-长上下文模型在处理NL2SQL任务时&#xff0c;相较于传统模型&#xff0c;有哪些显著的优势。NL2SQL&#xff08;自然语言转SQL&#xff09;技术旨在将用户自然语言提问自动转换为结构化查询语句&#…

A Large Recurrent Action Model: xLSTM Enables Fast Inference for Robotics Tasks

奥地利林茨约翰开普勒大学机器学习研究所 ELLIS 小组&#xff0c;LIT 人工智能实验室奥地利林茨 NXAI 有限公司谷歌 DeepMind米拉 - 魁北克人工智能研究所 摘要 近年来&#xff0c;强化学习&#xff08;Reinforcement Learning, RL&#xff09;领域出现了一种趋势&#xff0c;…

DeepSeek本地部署+自主开发对话Web应用

文章目录 引言前端部分核心页面DeepSeek.vueMyModal.vue 后端部分WebSocketConfig 配置类AbstractDeepSeekToolDeepSeekWebSocketHandler 数据库设计总结 引言 最近DeepSeep横空出世&#xff0c;在全球内掀起一股热潮&#xff0c;到处都是满血大模型接入的应用&#xff0c;但这…

DMA 定制固件教程:小白跟做即得单人固件,超详细纯喂饭教程,100% 成功秘籍!FPGA仿真1:1、中断逻辑和TLP核心都在。

DMA 定制固件教程 小白跟着操作做可以做出的单人固件 图文教程 链接&#xff1a;https://docs.qq.com/doc/DQ01lVGtHelROVHNv 本图文教程包含内容&#xff1a; 一、DMA仿真技术采集真实单人固件 二、网卡TLP仿真固件生成 三、DMA仿真技术io、中断逻辑&#xff0c;从零仿真 四、…

Linux | Ubuntu 与 Windows 双系统安装 / 高频故障 / UEFI 安全引导禁用

注&#xff1a;本文为 “buntu 与 Windows 双系统及高频故障解决” 相关文章合辑。 英文引文&#xff0c;机翻未校。 How to install Ubuntu 20.04 and dual boot alongside Windows 10 如何将 Ubuntu 20.04 和双启动与 Windows 10 一起安装 Dave’s RoboShack Published in…

spring中的注解介绍

本篇文章专门用来介绍spring中的各种注解。 1、RestController 1、含义 2、举例 3、使用场景 RestController 通常用于开发 RESTful API&#xff0c;适合返回 JSON 或 XML 数据的场景 4、总结 RestController 是 Spring 中用于简化 RESTful Web 服务开发的注解&#xff0c;它结…

JVM生产环境问题定位与解决实战(二):JConsole、VisualVM到MAT的高级应用

生产问题定位指南&#xff1a;几款必备的可视化工具 引言 在上一篇文章中&#xff0c;详细的介绍了JDK自带的一系列命令行工具&#xff0c;&#xff0c;如jps、jmap、jstat、jstack以及jcmd等&#xff0c;这些工具为排查和诊断Java虚拟机&#xff08;JVM&#xff09;问题提供…

网页制作09-html,css,javascript初认识のhtml如何使用表单

表单主要用来收集客户端提供的相关信息。,使网页具有交互作用。在网页制作的过程中&#xff0c;常常需要使用表单&#xff0c;如进行会员注册&#xff0c;网上调查和搜索等 访问者可以使用如文本域列表框&#xff0c;复选框以及单选按钮之类的表单对象输入信息&#xff0c;然后…

基本网络安全的实现

基本网络安全的实现 一 &#xff1a;AAA AAA 是Authentication&#xff0c;Authorization and Accounting&#xff08;认证、授权和计费&#xff09;的简 称&#xff0c;它提供了一个用来对认证、授权和计费这三种安全功能进行配置的一致性框架&#xff0c; 它是对网络安全…

Jupyter Notebook~Anaconda3安装教程

一、下载anaconda&#xff1a; https://mirrors.tuna.tsinghua.edu.cn/anaconda/archive/ 百度网盘通道&#xff0c;链接:https://pan.baidu.com/s/1gyVDG2p71neFXi8VwXgvEQ?pwdewn7提取码: ewn7 二、安装 1、右击安装软件选择【以管理员身份运行】&#xff0c;点击【Next】…

【运维】内网服务器借助通过某台可上外网的服务器实现公网访问

背景&#xff1a; 内网服务器无法连接公网,但是办公电脑可以连接内网服务器又可以连接公网。 安装软件 1、frp 2、ccproxy 配置 1、内网服务器 # 内网服务器启动frp服务配置文件参考vi frps.ini# frps.ini [common] bind_port 7000# 备注: bind_port端口可以随意配置。配置完…

php 对接mqtt 完整版本,订阅消息,发送消息

首先打开链接如何在 PHP 项目中使用 MQTT 根据文章让所用依赖安装一下&#xff1a; composer require php-mqtt/client 安装之后弄一个部署 之后在工具里边可以相应链接上 接下来是代码&#xff1a; /**** 订阅消息* return void* throws \PhpMqtt\Client\Exceptions\Confi…

(2.26 “详细分析示例“ 暴力+位运算 最长优雅子数组)leetcode 2401

a&b0说明a和b的每一位都是一个0和一个1 不存在两个均为1的位次 a|0a 0与任何数|都等于它本身 &#xff08;mask&#xff09;的作用&#xff1a; 担心两数的1在用一位导致mask覆盖了&#xff1f; 答&#xff1a;出现这种情况说明mask与nums j后就直接break 由&#xff1a;…

数据开发的简历及面试

简历 个人信息: 邮箱别写QQ邮箱, 写126邮箱/189邮箱等 学历>>本科及以上写,大专及以下不写 专业>>非计算机专业不写 政治面貌>>党员写, 群众不用写 掌握的技能: 精通 > 熟悉 > 了解 专业工具: 大数据相关的 公司: 如果没有可以写的>>金融服…