- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
双向循环链表list
?list是双向循环链表,,每一个元素都知道前面一个元素和后面一个元素。在STL中,list和vector一样,是两个常被使用的容器。和vector不一样的是,list不支持对元素的任意存取。list中提供的成员函数与vector类似,不过list提供对表首元素的操作push_front、pop_front,这是vector不具备的。和vector另一点不同的是,list的迭代器不会存在失效的情况,他不像vector会保留备份空间,在超过容量额度时重新全部分配内存,导致迭代器失效;list没有备份空间的概念,出入一个元素就申请一个元素的空间,所以它的迭代器不会失效。还是举《C++之vector》中的例子:
int data[6]={3,5,7,9,2,4};
listint lidata(data, data+6);
lidata.push_back(6);
...
list初始化时,申请的空间大小为6,存放下了data中的6个元素,当向lidata插入第7个元素“6”时,list申请新的节点单元,插入到list链表中,数据存放结构如图1所示:
?
图1 list的存储结构
??????? list每次增加一个元素,不存在重新申请内存的情况,它的成本是恒定的。而vector每当增加关键元素的时候,都需要重新申请新的更大的内存空间,会调用元素的自身的复制构造函数,存在构造成本。在销毁旧内存的时候,会调用析构函数,存在析构成本。所以在存储复杂类型和大量元素的情况下,list比vector更有优势!?
双向链表,双链表既可以向前又向后链接他的元素。
? ??List将元素按顺序储存在链表中. 与 向量(vector)相比, 它允许快速的插入和删除,但是随机访问却比较慢。
assign() 给list赋值?
back() 返回最后一个元素?
begin() 返回指向第一个元素的迭代器?
clear() 删除所有元素?
empty() 如果list是空的则返回true?
end() 返回末尾的迭代器?
erase() 删除一个元素?
front() 返回第一个元素?
get_allocator() 返回list的配置器?
insert() 插入一个元素到list中?
max_size() 返回list能容纳的最大元素数量?
merge() 合并两个list?
pop_back() 删除最后一个元素?
pop_front() 删除第一个元素?
push_back() 在list的末尾添加一个元素?
push_front() 在list的头部添加一个元素?
rbegin() 返回指向第一个元素的逆向迭代器?
remove() 从list删除元素?
remove_if() 按指定条件删除元素?
rend() 指向list末尾的逆向迭代器?
resize() 改变list的大小?
reverse() 把list的元素倒转?
size() 返回list中的元素个数?
sort() 给list排序?
splice() 合并两个list?
swap() 交换两个list?
unique() 删除list中重复的元素
?List使用实例1
#include iostream
#include list
#include numeric
#include algorithm
using namespace std;
//创建一个list容器的实例LISTINT
typedef listint LISTINT;
//创建一个list容器的实例LISTCHAR
typedef listchar LISTCHAR;
int main(int argc, char *argv[])
{
//--------------------------
//用list容器处理整型数据
//--------------------------
//用LISTINT创建一个名为listOne的list对象
LISTINT listOne;
//声明i为迭代器
LISTINT::iterator i;
//从前面向listOne容器中添加数据
listOne.push_front (2);
listOne.push_front (1);
//从后面向listOne容器中添加数据
listOne.push_back (3);
listOne.push_back (4);
//从前向后显示listOne中的数据
coutlistOne.begin()--- listOne.end():endl;
for (i = listOne.begin(); i != listOne.end(); ++i)
cout *i ;
cout endl;
//从后向后显示list
您可能关注的文档
最近下载
- 计算机视觉 第7章 摄像机成像模型.ppt VIP
- 2025年部编版新教材语文二年级上册第三单元教案设计.docx
- 宠物医院一例猫血栓诊治方案.pdf VIP
- 史铁生的课件.pptx VIP
- 2024-2025学年广东省深圳市南山育才集团九年级(上)期中语文试卷.doc VIP
- 北师大版七年级下册 第2章平行线 ---纸片翻折问题 专题练习(word版、含解析).docx VIP
- 2025-2026学年八年级数学上学期第一次月考01(江西专用,人教版2024八年级上册第十三章_第十四章)【含答案】.docx
- 介绍信 接洽函.docx VIP
- 2025年-2025秋形势与政策课件携手周边国家共创美好未来.pdf
- 第05讲 平行线中的翻折问题解题技巧(含解析)-2021-2022学年七年级数学下册常考点.pdf VIP
文档评论(0)