C++之list容器介绍及使用方式

本文详细介绍了C++中的list容器,包括其底层的双向循环链表结构、构造方法、元素访问与迭代器、元素修改操作、特殊操作如remove、unique、sort等,以及迭代器失效问题。此外,还对比了list与vector的区别。
摘要由CSDN通过智能技术生成

本文主要介绍了C++之list容器介绍及使用方式,具有很好的参考价值,希望对大家有所帮助。

一、list底层结构

list底层是带头节点的双向循环链表

  • 双向:可以从前往后,也可以从后往前遍历
  • 循环:找尾节点的时间复杂度为O( 1 )
  • 带头节点:代码实现简单,不用考虑链表为空等特殊情况,可令end()迭代器指向头节点的位置

二、构造方法

构造函数

1

2

3

4

5

6

7

list<int> l1;

list<int> l2(5, 3);

//迭代器

vector<int> v{ 1,2,3,4,5 };

list<int> l3(v.begin(), v.end());

//C++11

list<int> l4{ 1,2,3,4,5 };

拷贝构造函数

利用l1拷贝构造l2

1

2

list<int> l1{ 1,2,3,4,5 };

list<int> l2(l1);

三、元素访问和迭代器

back&front

1

2

3

list<int> l1{ 1,2,3,4,5 };

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

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

三种遍历方式

1

list<int> l1{ 1,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值