C++STL系列-04. list和forward_list

C++STL系列-04. list和forward_list

核心区别

特性 list forward_list
实现方式 双向链表 单向链表
内存开销 每个节点有两个指针(前向和后向) 每个节点只有一个指针(前向)
迭代器类型 双向迭代器 前向迭代器
大小查询 有 size() 方法 无 size() 方法(需要遍历计算)
反向遍历 支持(有 rbegin(), rend()) 不支持
性能 插入删除操作常数时间,但内存开销大 内存效率更高,但功能受限

list

cpp 复制代码
#include<iostream>
#include<list>
using namespace std;
void printList(list<int> l) {
	for (int i : l) {
		cout << i << " ";
	}
	cout << endl;
}
int main() {
	list<int>alvin(5,3);	//包含5个值为3的元素
	list<int>alvin1 = {1,2,3,4,5};	//初始化列表
	alvin1.assign(3,6);	//分配 3 个 值为 6 的元素, 前面的1,2,3,4,5会消失
	alvin1.push_front(1);	//头部添加元素
	alvin1.push_back(7);	//尾部添加元素
	auto it = alvin1.begin();
	alvin1.insert(it,5);	//指定位置插入元素
	alvin1.pop_front();	//删除首元素
	alvin1.pop_back();	//删除尾元素
	alvin1.erase(it);	//删除指定位置元素
	alvin1 = {1,2,3,4,5,5,5,6,7,8,9};	//重新填充
	alvin1.remove(5);	//删除所有等于值的元素. 打印结果 1,2,3,6,7,8,9
	alvin1.remove_if([](int n) { return n % 2 == 0; }); // 删除满足条件的值,比如所有偶数,打印结果 1,3,7,9
	alvin1 = {7,7,8,8,9,2,1,9,3,5,4,5,6,6};	
	alvin1.unique(); //删除连续重复的数  打印结果 7 8 9 2 1 9 3 5 4 5 6
	alvin1.sort();	//排序 1,2,3,4,5,5,6,7,8,9,9
	alvin1.merge(alvin);	//合并并且排序
	alvin1.reverse();	//反转
	alvin = {55,99,88};
	alvin1.swap(alvin);	//交换
	printList(alvin1);
	return 0;
}

forward_list 常用函数

push_front() - 在首部添加元素

pop_front() - 删除首部元素

insert_after() - 在指定位置后插入元素

erase_after() - 删除指定位置后的元素

before_begin() - 返回第一个元素之前的位置

sort() - 排序

merge() - 合并两个有序链表

splice_after() - 移动元素从一个链表到另一个

reverse() - 反转链表
双链表代码原理
单链表代码原理

相关推荐
近津薪荼6 小时前
递归专题5——快速幂
c++·学习·算法
郝学胜-神的一滴6 小时前
跨平台通信的艺术与哲学:Qt与Linux Socket的深度对话
linux·服务器·开发语言·网络·c++·qt·软件构建
小龙报6 小时前
【数据结构与算法】指针美学与链表思维:单链表核心操作全实现与深度精讲
c语言·开发语言·数据结构·c++·物联网·算法·链表
一匹电信狗15 小时前
【LeetCode_547_990】并查集的应用——省份数量 + 等式方程的可满足性
c++·算法·leetcode·职场和发展·stl
Queenie_Charlie16 小时前
小陶的疑惑2
数据结构·c++·树状数组
Queenie_Charlie17 小时前
小陶与杠铃片
数据结构·c++·树状数组
CoderCodingNo18 小时前
【GESP】C++四级/五级练习题 luogu-P1223 排队接水
开发语言·c++·算法
sycmancia18 小时前
C++进阶01——示例
开发语言·c++
CoderCodingNo18 小时前
【GESP】C++五级/四级练习题 luogu-P1413 坚果保龄球
开发语言·c++·算法
阿猿收手吧!18 小时前
【C++】C++原子操作:compare_exchange_weak详解
java·jvm·c++