当前位置:   article > 正文

C++(标准库):16---STL容器之(序列式容器list)_c++ empalce()

c++ empalce()

一、序列式容器概述

二、特点

  • ①总的来说:双向链表。只支持双向顺序访问。在list中任何位置进行插入和删除的速度都很快
  • ②设计目的:令容器在任何位置进行插入和删除都很快
  • 不支持随机访问,为了访问一个元素,必须遍历整个容器
  • 与其他容器相比,额外内存开销大

何时使用:

  • 容器需要不断地在中间插入或删除元素

三、头文件、using声明

  • 头文件:#include <list>
  • using声明:using std::list;

四、初始化

  • list<T>  v1; ==>v1是一个空的list
  • list<T> v2(v1); ===>v2是v1的副本,拷贝构造
  • list<T> v2=v1; ===>同上
  • list<T> v1(n,val); ===>初始化n个value
  • list<T> v1(iter1,iter2); ===>用迭代器iter1与iter2所指的区间内元素进行初始化
  • list<T> v1(n); ===>初始化n个元素,每个元素使用默认值(int为0,string为空...)
  • list<T> v1{a,b,c...}; ===>用元素a,b,c进行初始化
  • list<T> v1={a,b,c...}; ===>同上

、相关操作

1.运算符

  1. L1==L2;//判断L1和L2是否相等
  2. L1!=L2;//判断L1和L2是否相等
  3. >、>=、<、<= //以字典顺序进行比较

2.取值

  • 不能通过索引取值,只能遍历容器

六、相关函数

  • list不支持capacity()和reserve()、at()
  1. L.empty();//判断是否为空,返回布尔值
  2. L.size();//返回容器中的元素个数
  3. L.max_size();//返回容器的容量
  4. L.reverse();//将元素逆序
  1. L.front();//得到头元素
  2. L.back();//得到尾元素
  1. L1.swap(L2);//将L1和L2进行交换。容器的成员函数版本
  2. swap(L1,L2);//同上。系统函数版本
  3. L.assign(iter1,iter2);//将容器元素更换为一个迭代器的区间元素
  4. L.assign(n,t);//将容器元素变为n个t元素
  1. L.insert(iter,t);//在迭代器iter处插入t。返回所插位置处的迭代器
  2. L.insert(L.end(),10,t);//在容器L的末尾插入10个元素,每个元素都是t。返回新添加元素的第一个元素的迭代器
  3. L.insert(L.end(),{"a","b"...});//将后面花括号的每个元素插入容器v的尾部。返回新添加元素的第一个元素的迭代器
  4. L.insert(L.begin(),L2.end()-2,L2.end());//将容器L2的最后两个元素插入容器L的头部。返回新添加元素的第一个元素的迭代器
  5. 注意:上面这个用法,后面两个参数不能为自身容器的范围(L.insert(L.begin(),L.end()-2,L.end());是错误的)
  6. //利用insert的返回值,下面代码为一直在lst容器的头部插入元素(类似于push_front的功能)
  7. list<string> lst;
  8. auto iter=lst.begin();
  9. while(cin>> word)
  10. iter=lst.insert(iter,word);//insert函数每回执行完,返回容器的首元素位置
  1. L.push_front(t);//头部追加元素t
  2. L.push_back(t);//尾部追加元素t
  3. L.pop_back();//删除尾元素
  4. L.earse(iter);//删除迭代器iter所指位置处的元素。返回删除位置处后一个元素迭代器
  5. L.erase(iter1,iter2);//删除迭代器iter1与iter2区间内的元素。返回删除最后一个元素的后一个元素迭代器
  6. L.clear();//清空容器,重新初始化容器
  1. L.resize(n);//将容器v的元素变为n个。若n<原始元素个数,删除多于元素。若n>原始元素个数,则用默认初始值初始化容器
  2. L.resize(n,t);//将容器元素变为n个t。与容器原始个数无关
  3. list<int> L(5,666);
  4. L.resize(3);//L内有3个元素,都是666
  5. L.resize(8);;//L内有8个元素,前5个个是666,后3个都是0(默认)
  6. L.resize(10,666);//L内有10个元素,都是666
  1. //下面的两个函数,是在在内存中创建一个对象,然后添加进相应的位置
  2. L.empalce(iter,args);//在容器L的位置添加创建一个args对象
  3. L.emplace_back(args);//在容器L的尾部添加创建一个args对象
  4. L.emplace_front(args);//在容器L的头部添加创建一个args对象
  5. 例如
  6. class A{
  7. string name;int age;
  8. public:
  9. A(string name, int age);
  10. };
  11. int main()
  12. {
  13. list<A> L;
  14. L.emplace_back("C语言", 18);//在尾部创建一个元素
  15. L.emplace(v.begin(),"C++",18);//在容器L的头部添加一个元素
  16. }
  1. li.remove_if(t);//调用earse删除第一个值为t元素
  2. li.remove_if(条件);//删除参数参数为真的条件元素
  3. li.sort();//排序,默认升序
  4. li.sort(条件);//排序,参数条件取决于降序还是升序
  5. li.unique();//调用earse如果有单/多个相邻且相同的元素,则删除重复的元素
  6. li.unique(条件);//如果有多个相邻且满足参数条件的元素,则删除重复元素
  1. //t2也是list类型
  2. t.splice(iter,t2);//将t2容器元素添加到迭代器iter之前处,并且清空t2
  3. t.splice(iter,t2,iter2);//将t2容器内迭代器iter2处的元素添加到t容器的迭代器itrer处,并且移除iter2处元素
  4. t.splice(iter,t2,iter1,iter2);//将t2容器内迭代器iter1与iter2区间内的元素添加到t容器的iter处,并且删除迭代器iter1与iter2区间内的元素
  1. //m也是list类型
  2. t.merge(m);//要求t与m都是相同的排序规则(此版本为<),将m内元素全部插入t内且仍使用此排序规则,m内元素清空
  3. t.merge(m,条件);//将t与m以参数条件的方式合并,其余规则同上

七、容器的迭代器、引用、指针

  • 无论删除还是增加,list的迭代器、引用、指针都不会失效
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/一键难忘520/article/detail/843788
推荐阅读
相关标签
  

闽ICP备14008679号