当前位置:首页 » 《我的小黑屋》 » 正文

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

22 人参与  2024年04月26日 08:44  分类 : 《我的小黑屋》  评论

点击全文阅读


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

一、了解list的基本信息二、成员函数1、构造2、迭代器3、empty()4、size()5、front()6、back()7、push_front()8、pop_front()9、push_back()10、pop_back()11、insert()12、erase()13、swap()14、sort()15、reverse()

一、了解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());

2、迭代器

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

#include<list>#include<iostream>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;}

在这里插入图片描述

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<int>::iterator it = lt1.begin();//while (it != lt1.end())//{//cout << *it << " ";//it++;//}//cout << endl;//cout << lt1.empty() << endl;cout << lt1.size()<<endl;return 0;}

在这里插入图片描述

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;}

在这里插入图片描述

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;}

在这里插入图片描述

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;}

在这里插入图片描述

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;}

在这里插入图片描述

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;}

在这里插入图片描述

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;}

在这里插入图片描述

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位置之前插入100for (auto e : lt1){cout << e << " ";}cout << endl;return 0;}

在这里插入图片描述

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;}

在这里插入图片描述
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;}

在这里插入图片描述

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;}

在这里插入图片描述

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;}

在这里插入图片描述


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


点击全文阅读


本文链接:http://m.zhangshiyu.com/post/100308.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 难渡红尘,爱恨随风去小说精彩章节免费试读_陆梨初徐慕凡陆总章节世界观揭秘篇‌
  • 黄泉情难渡爽文(叶北宸凤念安),黄泉情难渡爽文
  • [夫人她要对暗号,世子他在***]小说精彩节选试读_[舒妗月洛知珩]章节彩蛋限时释出‌
  • 全书浏览小姑子要重新养一遍自己,让我给她买百万豪车(江梦瑶林霜)_小姑子要重新养一遍自己,让我给她买百万豪车(江梦瑶林霜)全书结局
  • 人面桃花长相忆纯净版(阮雾梨闻砚辞)全书免费_(阮雾梨闻砚辞)人面桃花长相忆纯净版后续(阮雾梨闻砚辞)
  • 等风等雨等不到你现已上架(夏语栀祁墨寒许青瑶)_等风等雨等不到你现已上架
  • 别后不知君回首(程十安傅临州)_别后不知君回首
  • 顾书程江仪(第九十九次被绑架失忆后,我觉醒了+后续+结局)_顾书程江仪列表_笔趣阁(第九十九次被绑架失忆后,我觉醒了+后续+结局)
  • 野火吻过薄情玫瑰全文免费无弹窗阅读_笔趣阁_魏景辰傅雯杉傅家全文免费无弹窗阅读_笔趣阁
  • 别后不知君回首全书+后续(程十安傅临州)列表_别后不知君回首全书+后续(程十安傅临州)别后不知君回首全书+后续在线
  • 人面桃花长相忆+后续+结局(阮雾梨闻砚辞阮见微)列表_人面桃花长相忆+后续+结局(阮雾梨闻砚辞阮见微)人面桃花长相忆+后续+结局在线
  • 南风等不来候鸟结局+番外全书+后续+结局(沈南风苏雨柔)列表_南风等不来候鸟结局+番外(沈南风苏雨柔)南风等不来候鸟结局+番外全书+后续+结局在线

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1