0

0

C++ list用法详解_C++双向链表常用操作

尼克

尼克

发布时间:2025-12-16 07:35:18

|

243人浏览过

|

来源于php中文网

原创

std::list是C++ STL中的双向链表容器,1. 需包含头文件,支持多种初始化方式;2. 提供push_front、push_back、insert等高效插入操作及pop_front、erase等删除操作,front和back可访问首尾元素;3. 不支持下标访问,需用迭代器或范围for循环遍历;4. 支持sort、reverse、unique、merge和splice等特殊操作,适合有序合并与去重;5. 适用于频繁中间增删和复杂结构调整场景,但不适用于频繁随机访问或内存敏感场合。

c++ list用法详解_c++双向链表常用操作

在C++中,std::list 是标准模板库(STL)提供的一个双向链表容器。它支持高效的插入和删除操作,特别适合频繁修改数据结构的场景。与 vector 和 deque 不同,list 的元素在内存中不是连续存储的,而是通过指针连接节点,因此随机访问效率较低,但中间位置的增删操作非常高效。

1. 头文件与基本定义

使用 list 需要包含头文件:

#include

定义方式如下:

  • std::list lst; // 存储整数的空链表
  • std::list dlst(5); // 包含5个默认值为0.0的元素
  • std::list<:string> slst{"a", "b", "c"}; // 初始化列表

2. 常用成员函数操作

list 提供了丰富的成员函数来管理元素:

立即学习C++免费学习笔记(深入)”;

插入操作:
  • lst.push_front(x):在链表头部插入元素 x
  • lst.push_back(x):在链表尾部插入元素 x
  • lst.insert(it, x):在迭代器 it 指向的位置前插入 x
删除操作:
  • lst.pop_front():删除第一个元素
  • lst.pop_back():删除最后一个元素
  • lst.erase(it):删除迭代器 it 指向的元素
  • lst.clear():清空所有元素
访问与查询:
  • lst.front():返回第一个元素的引用
  • lst.back():返回最后一个元素的引用
  • lst.empty():判断是否为空,返回 bool
  • lst.size():返回当前元素个数

3. 迭代器遍历

由于 list 不支持下标访问,必须使用迭代器进行遍历:

std::list lst = {1, 2, 3, 4, 5};
for (auto it = lst.begin(); it != lst.end(); ++it) {
    std::cout << *it << " ";
}

也可以使用范围 for 循环(C++11 起):

CoCo
CoCo

智谱AI推出的首个有记忆的企业自主Agent智能体

下载
for (const auto& val : lst) {
    std::cout << val << " ";
}

4. 特殊操作:合并、反转、去重

list 提供了一些特有的高效算法操作:

  • lst.sort():对链表内元素排序(注意:不是全局 sort 函数)
  • lst.reverse():反转链表顺序
  • lst.unique():去除连续重复元素(常用于已排序链表)
  • lst.merge(other):将另一个已排序链表合并进来,并保持有序
  • lst.splice(it, other, o_it):将 other 中某个元素移动到当前链表 it 位置前

这些操作都在原链表上进行,无需额外空间,效率很高。

5. 实际使用建议

list 最适合以下场景:

  • 需要频繁在序列中间插入或删除元素
  • 不关心元素的内存连续性
  • 经常做拼接、拆分、移动等复杂结构调整

不适合的场景:

  • 需要频繁随机访问某一下标元素(应使用 vector)
  • 内存占用敏感(每个节点有额外指针开销)
  • 追求缓存友好性(非连续存储导致缓存命中率低)

基本上就这些。std::list 在特定场合下非常有用,理解其特性有助于写出更高效的代码。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

338

2023.08.02

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

387

2023.09.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

338

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

542

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

53

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

197

2025.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

53

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

100

2025.10.23

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

1

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.7万人学习

C# 教程
C# 教程

共94课时 | 7.2万人学习

C 教程
C 教程

共75课时 | 4.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号