【C++】list的使用

今天我们来进入到C++另一个容器list的学习


目录

一、list的介绍

二、list的使用

2.1 构造函数

2.2 迭代器函数接口

2.3 容量函数接口

2.4 元素访问函数接口

2.5 常用修改函数接口

2.6 常用操作函数接口


一、list的介绍

文档介绍:list - C++ Reference (cplusplus.com)

1. list是可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代。

2. list的底层是带头双向循环链表结构,双向链表中每个元素存储在互不相关的独立节点,在节点中通过指针指向其前一个元素和后一个元素。

3. list与forward_list非常相似:最主要的不同在于forward_list是单链表,只能朝前迭代。

4. 与其他的序列式容器相比(array,vector,deque),list通常在任意位置进行插入、移除元素的执行效率更好。

5. 与其他序列式容器相比,list和forward_list最大的缺陷是不支持任意位置的随机访问,比如:要访问list的第6个元素,必须从已知的位置(比如头部或者尾部)迭代到该位置,在这段位置上迭代需要线性的时间开销;list还需要一些额外的空间,以保存每个节点的相关联信息(对于存储类型较小元素的大list来说这可能是一个不可忽略的缺陷)

二、list的使用

对于先前学习过string和vectot的我们来说,上手list轻轻松松,不过需注意的是list是基于链表实现的容器,所以就没有reserve这些关于内存分配的函数接口。

2.1 构造函数

构造函数(constructor)接口说明
list (size_type n, const value_type& val = value_type())构造的list中包含n个值为val的元素
list()构造空的list
list (const list& x)拷贝构造函数
list (InputIterator first, InputIterator last)用[first, last)区间中的元素构造list,迭代器构造

 

2.2 迭代器函数接口

函数声明接口说明
begin返回第一个元素的迭代器
end返回最后一个元素下一个位置的迭代器
rbegin返回第一个元素的reverse_iterator,即end位置(注意返回的是反向迭代器)
rend返回最后一个元素下一个位置的 reverse_iterator,即begin位置(注意返回的是反向迭代器)

2.3 容量函数接口

函数声明接口说明
empty检测list是否为空,是返回true,否则返回false
size返回list中有效节点的个数

2.4 元素访问函数接口

函数声明接口说明
front返回list的第一个节点中值的引用
back返回list的最后一个节点中值的引用

2.5 常用修改函数接口

函数声明接口说明
push_front在list首元素前插入值为val的元素
pop_front删除list中第一个元素
push_back在list尾部插入值为val的元素
pop_back删除list中最后一个元素
insert在list的position位置中插入值为val的元素
erase删除lis中position位置的元素
swap交换两个list中的元素
clear清空list中的有效元素

2.6 常用操作函数接口

函数声明接口说明
splice将元素从x剪切插入到list指定位置中
remove去除list中重复的值为val的节点
sort(不推荐使用)对list中的节点进行排序

在这里提醒一下sort函数的效率是很低的,如果想要对list中的值进行排序,我们可以先将list中的值拷贝到vector中,再对vector进行排序后最后再拷贝回list中:

#include<iostream>
#include<vector>
#include<list>
#include<algorithm>
using namespace std;
int main()
{
	srand(time(0));
	list<int> L1;
	list<int> L2;
	int val;
	for (int i = 0; i < 10000000; ++i)
	{
		val = rand() + i;
		L1.push_back(val);
		L2.push_back(val);
	}
	int begin1 = clock();
	//将将list中的值拷贝到vector中
	vector<int> V;
	for (auto a : L1)
	{
		V.push_back(a);
	}
	//再对vector进行排序后最后再拷贝回list中
	sort(V.begin(), V.end());
	L1.clear();
	for (auto a : V)
	{
		L1.push_back(a);
	}
	int end1 = clock();
	//直接使用list提供的sort来排序
	int begin2 = clock();
	L2.sort();
	int end2 = clock();
	cout << "vector sort:" << end1 - begin1 << endl;
	cout << "list sort:" << end2 - begin2 << endl;
	return 0;
}

release环境下运行结果:

我们可以看到即使将list中的值转移到了vector中进行排序但是效率还是比用list中提供的sort接口快很多。


本期博客到这里就结束了,下一期很快就和大家见面了~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

1e-12

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值