C++ - 数据容器之 list(创建与初始化、元素访问、容量判断、元素遍历、添加元素、删除元素)

一、创建与初始化

  • 引入 <list> 并使用 std 命名空间
cpp 复制代码
#include <list>

using namespace std;
  1. 创建一个空 list
cpp 复制代码
list<int> my_list;
  1. 创建一个包含 5 个元素,每个元素初始化为 0 的 list
cpp 复制代码
list<int> my_list(5);
  1. 创建一个包含 5 个元素,每个元素初始化为 100 的 list
cpp 复制代码
list<int> my_list(5, 100);
  1. 初始化 list
cpp 复制代码
list<int> my_list = { 1, 2, 3, 4, 5 };

二、元素访问

  • 首尾元素访问
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 10, 20, 30 };

	int result1 = my_list.front();

	cout << "第一个元素:" << result1 << endl;

	int result2 = my_list.back();

	cout << "最后一个元素:" << result2 << endl;

	return 0;
}
复制代码
# 输出结果

第一个元素:10
最后一个元素:30

三、容量判断

  1. 获取 list 的大小
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 10, 20, 30 };

	cout << "大小:" << my_list.size() << endl;

	return 0;
}
复制代码
# 输出结果

大小:3
  1. 获取 list 的是否为空
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 10, 20, 30 };

	cout << "是否为空:" << (my_list.empty() ? "是" : "否") << endl;

	return 0;
}
复制代码
# 输出结果

四、元素遍历

  1. 正向遍历
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 10, 20, 30 };

	for (auto it = my_list.begin(); it != my_list.end(); ++it) {
		cout << *it << endl;
	}

	return 0;
}
复制代码
# 输出结果

10
20
30
  1. 反向遍历
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 10, 20, 30 };

	for (auto rit = my_list.rbegin(); rit != my_list.rend(); ++rit) {
		cout << *rit << endl;
	}

	return 0;
}
复制代码
# 输出结果

30
20
10
  1. 范围 for 循环
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 10, 20, 30 };

	for (int val : my_list) {
		cout << val << endl;
	}

	return 0;
}
复制代码
# 输出结果

10
20
30

五、添加元素

  1. 在末尾添加元素
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 1, 2, 3 };

	for (int val : my_list) {
		cout << val << endl;
	}

	cout << "-----" << endl;

	my_list.push_back(4);

	for (int val : my_list) {
		cout << val << endl;
	}

	return 0;
}
复制代码
# 输出结果

1
2
3
-----
1
2
3
4
  1. 在开头添加元素
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 1, 2, 3 };

	for (int val : my_list) {
		cout << val << endl;
	}

	cout << "-----" << endl;

	my_list.push_front(4);

	for (int val : my_list) {
		cout << val << endl;
	}

	return 0;
}
复制代码
# 输出结果

1
2
3
-----
4
1
2
3
  1. 在指定位置插入元素
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 1, 2, 3 };

	for (int val : my_list) {
		cout << val << endl;
	}

	cout << "-----" << endl;

	auto it = my_list.begin();
	advance(it, 1); // 移动到第 2 个位置
	my_list.insert(it, 5); // 在第 2 个位置插入元素

	for (int val : my_list) {
		cout << val << endl;
	}

	return 0;
}
复制代码
# 输出结果

1
2
3
-----
1
5
2
3

六、删除元素

  1. 删除末尾元素
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 1, 2, 3 };

	for (int val : my_list) {
		cout << val << endl;
	}

	cout << "-----" << endl;

	my_list.pop_back();

	for (int val : my_list) {
		cout << val << endl;
	}

	return 0;
}
复制代码
# 输出结果

1
2
3
-----
1
2
  1. 删除开头元素
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 1, 2, 3 };

	for (int val : my_list) {
		cout << val << endl;
	}

	cout << "-----" << endl;

	my_list.pop_front();

	for (int val : my_list) {
		cout << val << endl;
	}

	return 0;
}
复制代码
# 输出结果

1
2
3
-----
2
3
  1. 删除指定位置元素
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 1, 2, 3 };

	for (int val : my_list) {
		cout << val << endl;
	}

	cout << "-----" << endl;

	auto it = my_list.begin();
	advance(it, 1); // 移动到第 2 个位置
	my_list.erase(it); // 删除第 2 个位置的元素

	for (int val : my_list) {
		cout << val << endl;
	}

	return 0;
}
复制代码
# 输出结果

1
2
3
-----
1
3
  1. 删除(所有等于 5 的元素)元素
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 1, 2, 3, 1, 2, 3 };

	for (int val : my_list) {
		cout << val << endl;
	}

	cout << "-----" << endl;

	my_list.remove(3);

	for (int val : my_list) {
		cout << val << endl;
	}

	return 0;
}
复制代码
# 输出结果

1
2
3
1
2
3
-----
1
2
1
2
  1. 清空 list
cpp 复制代码
#include <iostream>
#include <list>

using namespace std;

int main() {

	list<int> my_list = { 1, 2, 3 };

	for (int val : my_list) {
		cout << val << endl;
	}

	cout << "-----" << endl;

	my_list.clear();

	for (int val : my_list) {
		cout << val << endl;
	}

	return 0;
}
复制代码
# 输出结果

1
2
3
-----
相关推荐
@LetsTGBot搜索引擎机器人几秒前
打造属于你的 Telegram 中文版:汉化方案 + @letstgbot 搜索引擎整合教程
开发语言·python·搜索引擎·机器人·.net
CS创新实验室7 分钟前
典型算法题解:长度最小的子数组
数据结构·c++·算法·考研408
我有一些感想……9 分钟前
浅谈 BSGS(Baby-Step Giant-Step 大步小步)算法
c++·算法·数论·离散对数·bsgs
人工智能的苟富贵9 分钟前
使用 Tauri + Rust 构建跨平台桌面应用:前端技术的新边界
开发语言·前端·rust·electron
j_xxx404_11 分钟前
C++ STL:string类(3)|operations|string类模拟实现|附源码
开发语言·c++
调试人生的显微镜12 分钟前
Web 前端可视化开发工具深度解析,从拖拽搭建到真机调试的全链路思维
后端
課代表34 分钟前
VB.NET 与 C# 文件操作文本到二进制文件的读写
c#·二进制文件·vb.net·streamwriter·文本文件·读写·streamreader
调试人生的显微镜36 分钟前
苹果商城上架全流程详解,从开发者账号到开心上架(Appuploader)跨平台上传的免 Mac 实战指南
后端
我是唐青枫38 分钟前
C#.NET Cronos 实战:优雅解析与执行 Cron 表达式
c#·.net
GHZero43 分钟前
Java 之解读String源码(九)
java·开发语言