C++初阶:容器(Containers)list常用接口详解

2024-02-26 1703阅读

温馨提示:这篇文章已超过388天没有更新,请注意相关的内容是否还可用!

介绍完了vector类的相关内容后,接下来进入新的篇章,容器list介绍:


文章目录

  • 1.list的初步介绍
  • 2.list的定义(constructor)
  • 3.list迭代器( iterator )
  • 4.string的三种遍历
    • 4.1迭代器
    • 4.2范围for循环
    • 5. list capacity
    • 6.list element access
    • 7.list modifiers

      1.list的初步介绍

      C++初阶:容器(Containers)list常用接口详解

      1. list是可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代。
      2. list的底层是双向链表结构,双向链表中每个元素存储在互不相关的独立节点中,在节点中通过指针指向其前一个元素和后一个元素。
      3. list与forward_list非常相似:最主要的不同在于forward_list是单链表,只能朝前迭代,已让其更简单高效。
      4. 与其他的序列式容器相比(array,vector,deque),list通常在任意位置进行插入、移除元素的执行效率更好。
      5. 与其他序列式容器相比,list和forward_list最大的缺陷是不支持任意位置的随机访问,比如:要访问list的第6个元素,必须从已知的位置(比如头部或者尾部)迭代到该位置,在这段位置上迭代需要线性的时间开销;list还需要一些额外的空间,以保存每个节点的相关联信息(对于存储类型较小元素的大list来说这可能是一个重要的因素)

      C++初阶:容器(Containers)list常用接口详解


      2.list的定义(constructor)

      C++初阶:容器(Containers)list常用接口详解

      构造函数描述
      list(size_type n, const value_type& val = value_type())构造一个包含 n 个元素的列表,每个元素初始化为 val。
      list()构造一个空列表。
      list(const list& x)拷贝构造函数。构造一个包含 x 中每个元素副本的列表。
      list(InputIterator first, InputIterator last)用区间 [first, last) 中的元素构造一个列表。
      #include
      #include
      using namespace std;
      void test1()
      {
      	list lt1;//空参
      	list lt2(10, 2);//放进去10个二
      	string s("abc");
      	list lt3(s.begin(), s.end());//利用迭代器初始化
      }
      int main()
      {
      	test1();
      	return 0;
      }
      

      3.list迭代器( iterator )

      C++初阶:容器(Containers)list常用接口详解

      迭代器说明
      begin获取第一个数据位置的iterator/const_iterator
      end获取最后一个数据的下一个位置的iterator/const_iterator
      rbegin获取最后一个数据位置的reverse_iterator
      rend获取第一个数据前一个位置的reverse_iterator

      4.string的三种遍历

      4.1迭代器

      void test2()
      {
      	string s("abc");
      	list lt(s.begin(), s.end());
      	list::iterator it = lt.begin();
      	while (it != lt.end())
      	{
      		cout 
VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]