【C++】list的认识与使用

2024-07-21 1620阅读

​​

list的认识与使用

  • list的介绍
  • list的使用
    • Member functions(成员函数)
      • constuctor(构造函数)
      • destructor(析构函数)
      • operator=(赋值构造)
      • Iterators(迭代器)
        • begin
        • end
        • rbegin
        • rend
        • Capacity(容量)
          • empty
          • size
          • max_size
          • Element access(元素访问)
            • front
            • back
            • Modifiers(修饰符)
              • assign
              • push_front
              • pop_front
              • push_back
              • pop_back
              • insert
              • erase
              • swap
              • resize
              • clear
              • Operations(操作)
                • reverse
                • sort
                • Non-member function overloads(非成员函数重载)
                  • relational operators (list)
                  • swap (list)

                    list的介绍

                    ​​【C++】list的认识与使用

                    • std::list
                    • template class 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++】list的认识与使用

                      list的使用

                      Member functions(成员函数)

                      constuctor(构造函数)

                      【C++】list的认识与使用

                      • std::list::list
                      • 构造链表
                      • default (1)

                        explicit list (const allocator_type& alloc = allocator_type());

                        空容器构造函数(默认构造函数)

                        	list lt1;
                        
                        • fill (2)

                          explicit list (size_type n, const value_type& val = value_type(),

                          const allocator_type& alloc = allocator_type());

                          多参数构造函数

                          	list lt2(4, 100);
                          
                          • range (3)

                            template

                            list (InputIterator first, InputIterator last,

                            const allocator_type& alloc = allocator_type());

                            范围构造函数

                            	list lt3(lt2.begin(), lt2.end());
                            
                            • copy (4)

                              list (const list& x);

                              拷贝构造函数

                              	list lt4(lt3);
                              

                              destructor(析构函数)

                              【C++】list的认识与使用

                              • std::list::~list
                              • ~list();
                              • list的析构函数

                                operator=(赋值构造)

                                【C++】list的认识与使用

                                • std::list::operator=

                                • copy (1)

                                  list& operator= (const list& x);

                                • 分配内容

                                  	list lt1;
                                  	list lt2(4, 100);
                                  	lt1 = lt2;
                                  

                                  Iterators(迭代器)

                                  begin

                                  【C++】list的认识与使用

                                  • std::list::begin

                                  • iterator begin();

                                  • const_iterator begin() const;

                                  • 返回指向开始的迭代器

                                    end

                                    【C++】list的认识与使用

                                    • std::list::end
                                    • iterator end();
                                    • const_iterator end() const;
                                    • 返回指向结尾的迭代器
                                      	list lt(4, 100);
                                      	list::iterator it = lt.begin();
                                      	while (it != lt.end())
                                      	{
                                      		cout 
                                      		cout 
                                      		cout 
                                      		cout 
                                      		cout 
                                      		cout 
                                      		cout 
                                      		cout 
VPS购买请点击我

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

目录[+]