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

一、创建与初始化

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

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

二、元素访问

  • 只能直接访问第一个元素
cpp 复制代码
#include <iostream>
#include <forward_list>

using namespace std;

int main() {

	forward_list<int> fl = { 1, 2, 3 };

	int result = fl.front();

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

	return 0;
}

三、容量判断

  1. 获取 forward_list 是否为空
cpp 复制代码
#include <iostream>
#include <forward_list>

using namespace std;

int main() {

	forward_list<int> fl = { 10, 20, 30 };

	if (fl.empty()) {
		cout << "forward_list 是空的" << endl;
	}
	else {
		cout << "forward_list 不为空" << endl;
	}

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

forward_list 不为空
  1. 由于没有 size() 方法,需要手动计算
cpp 复制代码
#include <iostream>
#include <forward_list>

using namespace std;

int main() {

	forward_list<int> fl = { 1, 2, 3, 4, 5 };

	size_t count = distance(fl.begin(), fl.end());

	cout << "元素数量:" << count << endl;

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

元素数量:5

四、元素遍历

cpp 复制代码
#include <iostream>
#include <forward_list>

using namespace std;

int main() {

	forward_list<int> fl = { 1, 2, 3, 4, 5 };

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

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

1
2
3
4
5

五、添加元素

  1. 在头部插入元素
cpp 复制代码
#include <iostream>
#include <forward_list>

using namespace std;

int main() {

	forward_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
cpp 复制代码
#include <iostream>
#include <forward_list>

using namespace std;

int main() {

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

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

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

	my_list.emplace_front(4);

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

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

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

using namespace std;

int main() {

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

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

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

	// 在第 2 个元素后插入
	auto it = my_list.begin();
	advance(it, 1);
	my_list.insert_after(it, 4);

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

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

1
2
3
-----
1
2
4
3
cpp 复制代码
#include <iostream>
#include <forward_list>

using namespace std;

int main() {

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

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

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

	// 在第 2 个元素后插入
	auto it = my_list.begin();
	advance(it, 1);
	my_list.emplace_after(it, 4);

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

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

1
2
3
-----
1
2
4
3

六、删除元素

  1. 删除头部元素
cpp 复制代码
#include <iostream>
#include <forward_list>

using namespace std;

int main() {

	forward_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. 删除指定位置后的元素
cpp 复制代码
#include <iostream>
#include <forward_list>

using namespace std;

int main() {

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

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

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

	// 删除第 1 个元素后的元素
	auto it = my_list.begin();
	my_list.erase_after(it);

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

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

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

using namespace std;

int main() {

	forward_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
-----
相关推荐
m0_7488735516 分钟前
C++与Rust交互编程
开发语言·c++·算法
ZTLJQ7 小时前
序列化的艺术:Python JSON处理完全解析
开发语言·python·json
2401_891482178 小时前
多平台UI框架C++开发
开发语言·c++·算法
H5css�海秀8 小时前
今天是自学大模型的第一天(sanjose)
后端·python·node.js·php
SuniaWang8 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
韩立学长8 小时前
Springboot校园跑腿业务系统0b7amk02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
sheji34168 小时前
【开题答辩全过程】以 基于springboot的扶贫系统为例,包含答辩的问题和答案
java·spring boot·后端
88号技师8 小时前
2026年3月中科院一区SCI-贝塞尔曲线优化算法Bezier curve-based optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法
t198751288 小时前
三维点云最小二乘拟合MATLAB程序
开发语言·算法·matlab
无敌昊哥战神8 小时前
【LeetCode 257】二叉树的所有路径(回溯法/深度优先遍历)- Python/C/C++详细题解
c语言·c++·python·leetcode·深度优先