• 【C++】---STL之list详解


    一、了解list的基本信息

    1、库里面的list是一个带头双向循环链表结构!

    2、优点:可以在任意位置进行插入删除,插入删除的效率比较高。

    3、缺点:不支持任意位置的随机访问(因为物理空间不连续!)

    二、成员函数

    1、构造

    在这里插入图片描述

    explicit list (const allocator_type& alloc = allocator_type());	//构造空list
     
    explicit list (size_type n, const value_type& val = value_type(),//构造一个有n个元素值为val的list
                    const allocator_type& alloc = allocator_type());
     
    template <class InputIterator>//构造一个list,值为InputIterator的first到last之间的元素
      list (InputIterator first, InputIterator last,
             const allocator_type& alloc = allocator_type());
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    2、迭代器

    在这里插入图片描述
    在这里插入图片描述

    #include
    #include
    using namespace std;
    
    int main()
    {
    	list<int> lt1;
    
    
    	lt1.push_back(1);
    	lt1.push_back(2);
    	lt1.push_back(3);
    	lt1.push_back(4);
    	lt1.push_back(5);
    
    	list<int>::iterator it = lt1.begin();
    	while (it != lt1.end())
    	{
    		cout << *it << " ";
    		it++;
    	}
    	cout << endl;
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    在这里插入图片描述

    3、empty()

    在这里插入图片描述
    在这里插入图片描述

    4、size()

    在这里插入图片描述

    int main()
    {
    	list<int> lt1;
    
    
    	lt1.push_back(1);
    	lt1.push_back(2);
    	lt1.push_back(3);
    	lt1.push_back(4);
    	lt1.push_back(5);
    
    	//list::iterator it = lt1.begin();
    	//while (it != lt1.end())
    	//{
    	//	cout << *it << " ";
    	//	it++;
    	//}
    	//cout << endl;
    
    	//cout << lt1.empty() << endl;
    
    	cout << lt1.size()<<endl;
    
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    在这里插入图片描述

    5、front()

    在这里插入图片描述

    int main()
    {
    	list<int> lt1;
    
    
    	lt1.push_back(1);
    	lt1.push_back(2);
    	lt1.push_back(3);
    	lt1.push_back(4);
    	lt1.push_back(5);
    
    	cout << lt1.front() << endl;
    
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    在这里插入图片描述

    6、back()

    在这里插入图片描述

    int main()
    {
    	list<int> lt1;
    
    
    	lt1.push_back(1);
    	lt1.push_back(2);
    	lt1.push_back(3);
    	lt1.push_back(4);
    	lt1.push_back(5);
    
    	//cout << lt1.front() << endl;
    	cout << lt1.back() << endl;
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    在这里插入图片描述

    7、push_front()

    在这里插入图片描述

    int main()
    {
    	list<int> lt1;
    
    	lt1.push_front(1);
    	lt1.push_front(2);
    	lt1.push_front(3);
    	lt1.push_front(4);
    	lt1.push_front(5);
    	
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    在这里插入图片描述

    8、pop_front()

    在这里插入图片描述

    int main()
    {
    	list<int> lt1;
    
    	lt1.push_front(1);
    	lt1.push_front(2);
    	lt1.push_front(3);
    	lt1.push_front(4);
    	lt1.push_front(5);
    	
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    
    	lt1.pop_front();
    	lt1.pop_front();
    	lt1.pop_front();
    
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28

    在这里插入图片描述

    9、push_back()

    在这里插入图片描述

    int main()
    {
    	list<int> lt1;
    
    	lt1.push_back(1);
    	lt1.push_back(2);
    	lt1.push_back(3);
    	lt1.push_back(4);
    	lt1.push_back(5);
    
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    在这里插入图片描述

    10、pop_back()

    在这里插入图片描述

    int main()
    {
    	list<int> lt1;
    
    	lt1.push_back(1);
    	lt1.push_back(2);
    	lt1.push_back(3);
    	lt1.push_back(4);
    	lt1.push_back(5);
    
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    
    	lt1.pop_back();
    	lt1.pop_back();
    	lt1.pop_back();
    
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27

    在这里插入图片描述

    11、insert()

    在这里插入图片描述

    int main()
    {
    	list<int> lt1;
    
    	lt1.push_back(1);
    	lt1.push_back(2);
    	lt1.push_back(3);
    	lt1.push_back(4);
    	lt1.push_back(5);
    
    	list<int>::iterator pos = find(lt1.begin(), lt1.end(), 2);//在链表中查找值为2的元素,并返回它的迭代器
    
    	lt1.insert(pos, 100);// 在pos位置之前插入100
    
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    在这里插入图片描述

    12、erase()

    在这里插入图片描述

    改变底层的数据结构,迭代器失效:

    int main()
    {
    	list<int> lt1;
    
    	lt1.push_back(1);
    	lt1.push_back(2);
    	lt1.push_back(3);
    	lt1.push_back(4);
    	lt1.push_back(5);
    
    	list<int>::iterator pos = find(lt1.begin(), lt1.end(), 3);// 擦除元素值为3的
    
    	lt1.erase(pos);
    
    	cout << *pos << endl;// pos的位置的元素的值已经被删除了。
    	//此时如果不对pos的位置的迭代器进行重新赋值更新,那么pos就是一个野指针,非法访问。
    
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    在这里插入图片描述
    erase删除pos位置元素后,pos位置之后的元素会往前搬移,没有导致底层空间的改变,理论上讲迭代 器不应该会失效,但是:如果pos刚好是最后一个元素,删完之后pos刚好是end的位置,而end位置是 没有元素的,那么pos就失效了。因此删除list中任意位置上元素时,vs就认为该位置迭代器失效 了。

    13、swap()

    在这里插入图片描述

    int main()
    {
    	list<int> lt1;
    
    	lt1.push_back(1);
    	lt1.push_back(2);
    	lt1.push_back(3);
    	lt1.push_back(4);
    	lt1.push_back(5);
    
    	list<int> lt2;
    
    	lt2.push_back(1);
    	lt2.push_back(1);
    	lt2.push_back(1);
    	lt2.push_back(1);
    	lt2.push_back(1);
    
    	cout << "lt1交换前:";
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    
    
    	lt1.swap(lt2);// lt1 和 lt2内容进行交换
    
    	cout << "lt1交换后:";
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37

    在这里插入图片描述

    14、sort()

    在这里插入图片描述
    sort()函数默认是:排升序!

    int main()
    {
    	list<int> lt1;
    
    	lt1.push_back(4);
    	lt1.push_back(3);
    	lt1.push_back(5);
    	lt1.push_back(1);
    	lt1.push_back(2);
    
    
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    
    	lt1.sort();
    
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27

    在这里插入图片描述

    15、reverse()

    在这里插入图片描述

    int main()
    {
    	list<int> lt1;
    
    	lt1.push_back(4);
    	lt1.push_back(3);
    	lt1.push_back(5);
    	lt1.push_back(1);
    	lt1.push_back(2);
    
    
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    
    	lt1.sort();
    
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	cout << endl;
    
    	lt1.reverse();
    
    	for (auto e : lt1)
    	{
    		cout << e << " ";
    	}
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33

    在这里插入图片描述


    好了,今天的分享就到这里了
    如果对你有帮助,记得点赞👍+关注哦!
    我的主页还有其他文章,欢迎学习指点。关注我,让我们一起学习,一起成长吧!
    在这里插入图片描述

  • 相关阅读:
    vm问题记录
    Simulink代码生成: 查表模块及其代码
    Mysql中校对集utf8_unicode_ci与utf8_general_ci的区别
    ABC310F Make 10 Again
    SPL-介绍(一)
    记一次 .NET 某埋线管理系统 崩溃分析
    Selenium最新版谷歌浏览器驱动的下载及使用
    Android 基础知识4-1 用户界面简介VIewGroup、Onclick事件处理
    算法刷题 week4
    天津权威大数据培训机构 数据分析师的就业薪资多少?
  • 原文地址:https://blog.csdn.net/weixin_75128035/article/details/138157023