list容器

1. list 的介绍

list 是序列容器,允许在序列中的任何位置进行O(1)时间复杂度的插入和删除操作以及双向迭代。

list 容器实现为带头结点双向链表,双向链表可以将它们包含的每个元素存储在不同且不相关的存储位置。

2. list 的使用

2.1 构造函数

  1. list()

构造一个空的list容器。

  1. list(const list& x)

用一个 list 容器去构造另一个 list 容器。

  1. list(size_t n, int x)

用 n 个元素去构造一个 list 。

  1. list(Inputiterator first, Inputiterator last)

用一段迭代器区间去构造 list 容器。

  1. list(initializer_list)

C++11新添加的构造函数,用一段列表去构造 list 容器。

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

using namespace std;

int main()
{
	list<int> l1;
	for (auto& e : l1)
	{
		cout << e << ' ';
	}
	cout << endl;

	list<int> l2(5, 1);
	for (auto& e : l2)
	{
		cout << e << ' ';
	}
	cout << endl;

	list<int> l3(l2);
	for (auto& e : l3)
	{
		cout << e << ' ';
	}
	cout << endl;

	list<int> l4(l3.begin(), l3.end());
	for (auto& e : l4)
	{
		cout << e << ' ';
	}
	cout << endl;
	
	list<int> l5 = { 1,2,3,4 };
	for (auto& e : l5)
	{
		cout << e << ' ';
	}
	cout << endl;

	return 0;
}

2.2 list 迭代器

  1. begin() + end()

返回第一个元素的迭代器和最后一个元素下一个位置的迭代器。

  1. rbegin() + rend()

和正向迭代器刚好相反,返回最后一个元素位置的迭代器和第一个元素前面一个元素的位置。

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

using namespace std;

int main()
{
	list<int> l1 = { 1,2,3,4 };
	
	list<int>::iterator it1 = l1.begin();
	while (it1 != l1.end())
	{
		cout << *it1 << ' ';
		it1++;
	}
	cout << endl;

	list<int>::reverse_iterator it2 = l1.rbegin();
	while (it2 != l1.rend())
	{
		cout << *it2 << ' ';
		it2++;
	}
	cout << endl;

	return 0;
}

2.3 list 的一些常用接口介绍

  1. push_back(int x)

尾插一个元素。

  1. pop_back()

尾删一个元素。

  1. insert(iterator pos, int x)

在指定迭代器的前一个元素后面插入元素。

  1. size()

计算元素大小。

  1. front()

返回第一个元素。

  1. back()

返回最后一个元素。

  1. erase(iterator pos)

删除迭代器位置元素。

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

using namespace std;

int main()
{
	list<int> l1 = { 1,2,3,4 };

	l1.push_back(5);
	for (auto& e : l1)
	{
		cout << e << ' ';
	}
	cout << endl;

	l1.pop_back();
	for (auto& e : l1)
	{
		cout << e << ' ';
	}
	cout << endl;

	l1.insert(l1.begin(), 10);
	for (auto& e : l1)
	{
		cout << e << ' ';
	}
	cout << endl;

	cout << l1.size() << endl;
	cout << l1.front() << endl;
	cout << l1.back() << endl;

	l1.erase(l1.begin());
	for (auto& e : l1)
	{
		cout << e << ' ';
	}
	cout << endl;

	return 0;
}
相关推荐
草履虫建模8 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq10 小时前
分布式系统安全通信
开发语言·c++·算法
学嵌入式的小杨同学10 小时前
【Linux 封神之路】信号编程全解析:从信号基础到 MP3 播放器实战(含核心 API 与避坑指南)
java·linux·c语言·开发语言·vscode·vim·ux
Re.不晚11 小时前
Java入门17——异常
java·开发语言
精彩极了吧11 小时前
C语言基本语法-自定义类型:结构体&联合体&枚举
c语言·开发语言·枚举·结构体·内存对齐·位段·联合
南极星100512 小时前
蓝桥杯JAVA--启蒙之路(十)class版本 模块
java·开发语言
baidu_2474386112 小时前
Android ViewModel定时任务
android·开发语言·javascript
CSDN_RTKLIB12 小时前
【四个场景测试】源文件编码UTF-8 BOM
c++
Dev7z12 小时前
基于 MATLAB 的铣削切削力建模与仿真
开发语言·matlab
不能隔夜的咖喱12 小时前
牛客网刷题(2)
java·开发语言·算法