0

0

c++怎么使用list容器_c++ list容器用法与遍历方法

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-10-16 19:25:02

|

346人浏览过

|

来源于php中文网

原创

list是STL中的双向链表,支持高效插入删除但不支持随机访问,需通过迭代器或范围for循环遍历,常用操作包括push_back、push_front、erase等,适合频繁修改的场景。

c++怎么使用list容器_c++ list容器用法与遍历方法

在C++中,list 是 STL(标准模板库)提供的一个双向链表容器,位于 头文件中。它支持高效地在任意位置插入和删除元素,但不支持随机访问。下面介绍 list 的基本用法和常见的遍历方法。

1. 包含头文件并声明 list 容器

使用 list 前必须包含对应的头文件:

#include
#include iostream>

声明一个 list 容器的常见方式:

std::list my_list; // 存储 int 类型的 list
std::list name_list; // 存储 string 类型的 list

2. 常用操作方法

list 提供了丰富的成员函数来操作数据:

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

  • push_back(x):在末尾添加元素 x
  • push_front(x):在开头添加元素 x
  • pop_back():删除最后一个元素
  • pop_front():删除第一个元素
  • insert(pos, x):在迭代器 pos 指向的位置前插入 x
  • erase(pos):删除迭代器 pos 指向的元素
  • clear():清空所有元素
  • size():返回元素个数
  • empty():判断是否为空

示例代码:

my_list.push_back(10);
my_list.push_front(5);
my_list.push_back(20);
// 此时 list 中元素为:5 → 10 → 20

3. 遍历 list 容器的方法

由于 list 不支持下标访问,必须通过迭代器或范围 for 循环来遍历。

Khroma
Khroma

AI调色盘生成工具

下载

方法一:使用正向迭代器

for (std::list::iterator it = my_list.begin(); it != my_list.end(); ++it) {
    std::cout
}

方法二:使用 const_iterator(适用于只读访问)

for (std::list::const_iterator it = my_list.cbegin(); it != my_list.cend(); ++it) {
    std::cout
}

方法三:C++11 范围 for 循环(推荐,简洁)

for (const auto& value : my_list) {
    std::cout
}

方法四:反向遍历(从后往前)

for (auto rit = my_list.rbegin(); rit != my_list.rend(); ++rit) {
    std::cout
}

4. 实际例子:完整演示

#include stream>
#include
using namespace std; int main() {
    list nums;
    nums.push_back(1);
    nums.push_front(0);
    nums.push_back(2);
    cout
    for (const auto& n : nums) {
        cout
    }
    cout     cout
    for (auto rit = nums.rbegin(); rit != nums.rend(); ++rit) {
        cout
    }
    cout     return 0;
}

输出结果:

正向遍历: 0 1 2
反向遍历: 2 1 0

基本上就这些。list 适合频繁插入删除的场景,但若需要快速访问第 N 个元素,建议使用 vector。掌握迭代器和范围 for 循环是使用 list 的关键。不复杂但容易忽略细节,比如不能用下标直接访问。

相关专题

更多
string转int
string转int

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

318

2023.08.02

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

524

2023.09.20

string转int
string转int

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

318

2023.08.02

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

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

538

2024.08.29

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

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

52

2025.08.29

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

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

197

2025.08.29

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

42

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

74

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

23

2026.01.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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