当前位置:   article > 正文

C++STL(queue和list)_queue c++ list

queue c++ list

3.6 queue 容器

3.6.1 queue 基本概念

概念:Queue是一种先进先出(First In First Out,FIFO)的数据结构,它有两个出口

  • 队列容器允许从一端新增元素,从另一端移除元素
  • 队列中只有队头和队尾才可以被外界使用,因此队列不允许有遍历行为
  • 队列中进数据称为 --- 入队   `push`
  • 队列中出数据称为 --- 出队   `pop`

3.6.2 queue 常用接口

功能描述:栈容器常用的对外接口

构造函数

  • - `queue<T> que;`                                 //queue采用模板类实现,queue对象的默认构造形式
  • - `queue(const queue &que);`            //拷贝构造函数

赋值操作:

  • - `queue& operator=(const queue &que);`           //重载等号操作符

数据存取:

  • - `push(elem);`                             //往队尾添加元素
  • - `pop();`                                      //从队头移除第一个元素
  • - `back();`                                    //返回最后一个元素
  • - `front(); `                                  //返回第一个元素

大小操作:

  • - `empty();`            //判断堆栈是否为空
  • - `size(); `              //返回栈的大小

代码示例:

  1. #include <queue>
  2. #include <string>
  3. class Person{
  4. public:
  5. Person(string name, int age){
  6. this->m_Name = name;
  7. this->m_Age = age;
  8. }
  9. string m_Name;
  10. int m_Age;
  11. };
  12. void test01() {
  13. //创建队列
  14. queue<Person> q;
  15. //准备数据
  16. Person p1("唐僧", 30);
  17. Person p2("孙悟空", 1000);
  18. Person p3("猪八戒", 900);
  19. Person p4("沙僧", 800);
  20. //向队列中添加元素 入队操作
  21. q.push(p1);
  22. q.push(p2);
  23. q.push(p3);
  24. q.push(p4);
  25. //队列不提供迭代器,更不支持随机访问
  26. while (!q.empty()) {
  27. //输出队头元素
  28. cout << "队头元素-- 姓名: " << q.front().m_Name
  29. << " 年龄: "<< q.front().m_Age << endl;
  30. cout << "队尾元素-- 姓名: " << q.back().m_Name
  31. << " 年龄: " << q.back().m_Age << endl;
  32. cout << endl;
  33. //弹出队头元素
  34. q.pop();
  35. }
  36. cout << "队列大小为:" << q.size() << endl;
  37. }
  38. int main() {
  39. test01();
  40. system("pause");
  41. return 0;
  42. }

总结:

  • - 入队   --- push
  • - 出队   --- pop
  • - 返回队头元素   --- front
  • - 返回队尾元素   --- back
  • - 判断队是否为空   --- empty
  • - 返回队列大小   --- size

3.7 list容器

3.7.1 list基本概念

功能:将数据进行链式存储

        链表(list)是一种物理存储单元上非连续的存储结构,数据元素的逻辑顺序是通过链表中的指针链接实现的

        链表的组成:链表由一系列结点组成

        结点的组成:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域

        STL中的链表是一个双向循环链表,由于链表的存储方式并不是连续的内存空间,因此链表list中的迭代器只支持前移和后移,属于双向迭代器

list的优点:

  • 采用动态存储分配,不会造成内存浪费和溢出
  • 链表执行插入和删除操作十分方便,修改指针即可,不需要移动大量元素

list的缺点:

  • 链表灵活,但是空间(指针域) 和 时间(遍历)额外耗费较大

        List有一个重要的性质,插入操作和删除操作都不会造成原有list迭代器的失效,这在vector是不成立的。

        总结:STL中List和vector是两个最常被使用的容器,各有优缺点

3.7.2  list构造函数

功能描述:创建list容器

函数原型:

  • `list<T> lst;`                               //list采用采用模板类实现,对象的默认构造形式:
  • `list(beg,end);`                           //构造函数将[beg, end)区间中的元素拷贝给本身。
  • `list(n,elem);`                             //构造函数将n个elem拷贝给本身。
  • `list(const list &lst);`            //拷贝构造函数。

代码示例:

  1. #include <list>
  2. void printList(const list<int>& L) {
  3. for (list<int>::const_iterator it = L.begin(); it != L.end(); it++) {
  4. cout << *it << " ";
  5. }
  6. cout << endl;
  7. }
  8. void test01(){
  9. list<int>L1;
  10. L1.push_back(10);
  11. L1.push_back(20);
  12. L1.push_back(30);
  13. L1.push_back(40);
  14. printList(L1);
  15. list<int>L2(L1.begin(),L1.end());
  16. printList(L2);
  17. list<int>L3(L2);
  18. printList(L3);
  19. list<int>L4(10, 1000);
  20. printList(L4);
  21. }
  22. int main() {
  23. test01();
  24. system("pause");
  25. return 0;
  26. }

总结:list构造方式同其他几个STL常用容器,熟练掌握即可

3.7.3 list 赋值和交换

功能描述:给list容器进行赋值,以及交换list容器

函数原型:

  • `assign(beg, end);`            //将[beg, end)区间中的数据拷贝赋值给本身。
  • `assign(n, elem);`              //将n个elem拷贝赋值给本身。
  • `list& operator=(const list &lst);`         //重载等号操作符
  • `swap(lst);`                         //将lst与本身的元素互换。
  1. #include <list>
  2. void printList(const list<int>& L) {
  3. for (list<int>::const_iterator it = L.begin(); it != L.end(); it++) {
  4. cout << *it << " ";
  5. }
  6. cout << endl;
  7. }
  8. //赋值和交换
  9. void test01(){
  10. list<int>L1;
  11. L1.push_back(10);
  12. L1.push_back(20);
  13. L1.push_back(30);
  14. L1.push_back(40);
  15. printList(L1);
  16. //赋值
  17. list<int>L2;
  18. L2 = L1;
  19. printList(L2);
  20. list<int>L3;
  21. L3.assign(L2.begin(), L2.end());
  22. printList(L3);
  23. list<int>L4;
  24. L4.assign(10, 100);
  25. printList(L4);
  26. }
  27. //交换
  28. void test02(){
  29. list<int>L1;
  30. L1.push_back(10);
  31. L1.push_back(20);
  32. L1.push_back(30);
  33. L1.push_back(40);
  34. list<int>L2;
  35. L2.assign(10, 100);
  36. cout << "交换前: " << endl;
  37. printList(L1);
  38. printList(L2);
  39. cout << endl;
  40. L1.swap(L2);
  41. cout << "交换后: " << endl;
  42. printList(L1);
  43. printList(L2);
  44. }
  45. int main() {
  46. //test01();
  47. test02();
  48. system("pause");
  49. return 0;
  50. }

总结:list赋值和交换操作能够灵活运用即可

3.7.4 list 大小操作

功能描述:对list容器的大小进行操作

函数原型:

  • `size(); `                             //返回容器中元素的个数
  • `empty(); `                           //判断容器是否为空
  • `resize(num);`                   //重新指定容器的长度为num,若容器变长,则以默认值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除。
  • `resize(num, elem); `       //重新指定容器的长度为num,若容器变长,则以elem值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除。

代码示例:

  1. #include <list>
  2. void printList(const list<int>& L) {
  3. for (list<int>::const_iterator it = L.begin(); it != L.end(); it++) {
  4. cout << *it << " ";
  5. }
  6. cout << endl;
  7. }
  8. //大小操作
  9. void test01(){
  10. list<int>L1;
  11. L1.push_back(10);
  12. L1.push_back(20);
  13. L1.push_back(30);
  14. L1.push_back(40);
  15. if (L1.empty()){
  16. cout << "L1为空" << endl;
  17. }
  18. else
  19. {
  20. cout << "L1不为空" << endl;
  21. cout << "L1的大小为: " << L1.size() << endl;
  22. }
  23. //重新指定大小
  24. L1.resize(10);
  25. printList(L1);
  26. L1.resize(2);
  27. printList(L1);
  28. }
  29. int main() {
  30. test01();
  31. system("pause");
  32. return 0;
  33. }

总结:

  • - 判断是否为空   --- empty
  • - 返回元素个数   --- size
  • - 重新指定个数   --- resize

3.7.5 list 插入和删除

功能描述:对list容器进行数据的插入和删除

函数原型:

  • push_back(elem);//在容器尾部加入一个元素
  • pop_back();//删除容器中最后一个元素
  • push_front(elem);//在容器开头插入一个元素
  • pop_front();//从容器开头移除第一个元素
  • insert(pos,elem);//在pos位置插elem元素的拷贝,返回新数据的位置。
  • insert(pos,n,elem);//在pos位置插入n个elem数据,无返回值。
  • insert(pos,beg,end);//在pos位置插入[beg,end)区间的数据,无返回值。
  • clear();//移除容器的所有数据
  • erase(beg,end);//删除[beg,end)区间的数据,返回下一个数据的位置。
  • erase(pos);//删除pos位置的数据,返回下一个数据的位置。
  • remove(elem);//删除容器中所有与elem值匹配的元素。
  1. #include <list>
  2. void printList(const list<int>& L) {
  3. for (list<int>::const_iterator it = L.begin(); it != L.end(); it++) {
  4. cout << *it << " ";
  5. }
  6. cout << endl;
  7. }
  8. //插入和删除
  9. void test01(){
  10. list<int> L;
  11. //尾插
  12. L.push_back(10);
  13. L.push_back(20);
  14. L.push_back(30);
  15. //头插
  16. L.push_front(100);
  17. L.push_front(200);
  18. L.push_front(300);
  19. printList(L);
  20. //尾删
  21. L.pop_back();
  22. printList(L);
  23. //头删
  24. L.pop_front();
  25. printList(L);
  26. //插入
  27. list<int>::iterator it = L.begin();
  28. L.insert(++it, 1000);
  29. printList(L);
  30. //删除
  31. it = L.begin();
  32. L.erase(++it);
  33. printList(L);
  34. //移除
  35. L.push_back(10000);
  36. L.push_back(10000);
  37. L.push_back(10000);
  38. printList(L);
  39. L.remove(10000);
  40. printList(L);
  41. //清空
  42. L.clear();
  43. printList(L);
  44. }
  45. int main() {
  46. test01();
  47. system("pause");
  48. return 0;
  49. }

总结:

  • 尾插   --- push_back
  • 尾删   --- pop_back
  • 头插   --- push_front
  • 头删   --- pop_front
  • 插入   --- insert
  • 删除   --- erase
  • 移除   --- remove
  • 清空   --- clear

3.7.6 list 数据存取

功能描述:对list容器中数据进行存取

函数原型:

  • `front();`        //返回第一个元素。
  • `back();`         //返回最后一个元素。

代码示例:

  1. #include <list>
  2. //数据存取
  3. void test01(){
  4. list<int>L1;
  5. L1.push_back(10);
  6. L1.push_back(20);
  7. L1.push_back(30);
  8. L1.push_back(40);
  9. //cout << L1.at(0) << endl;//错误 不支持at访问数据
  10. //cout << L1[0] << endl; //错误 不支持[]方式访问数据
  11. cout << "第一个元素为: " << L1.front() << endl;
  12. cout << "最后一个元素为: " << L1.back() << endl;
  13. //list容器的迭代器是双向迭代器,不支持随机访问
  14. list<int>::iterator it = L1.begin();
  15. //it = it + 1;//错误,不可以跳跃访问,即使是+1
  16. }
  17. int main() {
  18. test01();
  19. system("pause");
  20. return 0;
  21. }

总结:

  • list容器中不可以通过[]或者at方式访问数据
  • 返回第一个元素   --- front
  • 返回最后一个元素   --- back

3.7.7 list 反转和排序

功能描述:将容器中的元素反转,以及将容器中的数据进行排序

函数原型:

  • `reverse();`   //反转链表
  • `sort();`        //链表排序
  1. void printList(const list<int>& L) {
  2. for (list<int>::const_iterator it = L.begin(); it != L.end(); it++) {
  3. cout << *it << " ";
  4. }
  5. cout << endl;
  6. }
  7. bool myCompare(int val1 , int val2){
  8. return val1 > val2;
  9. }
  10. //反转和排序
  11. void test01(){
  12. list<int> L;
  13. L.push_back(90);
  14. L.push_back(30);
  15. L.push_back(20);
  16. L.push_back(70);
  17. printList(L);
  18. //反转容器的元素
  19. L.reverse();
  20. printList(L);
  21. //排序
  22. L.sort(); //默认的排序规则 从小到大
  23. printList(L);
  24. L.sort(myCompare); //指定规则,从大到小
  25. printList(L);
  26. }
  27. int main() {
  28. test01();
  29. system("pause");
  30. return 0;
  31. }

总结:

  • 反转   --- reverse
  • 排序   --- sort (成员函数)
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/神奇cpp/article/detail/1001743
推荐阅读
相关标签
  

闽ICP备14008679号