list的介绍

list的底层是双向循环列表,每个节点包含:

数据域:存储元素值。

前驱指针(prev):指向前一个节点。

后继指针(next):指向后一个节点

特点:

节点在内存中不连续,通过指针链接

任意位置插入 / 删除只需修改指针(时间复杂度 O(1))

list的构造与初始化

cpp 复制代码
#include<list>
#include<iostream>
void test()
{
  list<int> l1;//构造无参空list
  list<int> l2(5,10);
  //用迭代器范围初始化(拷贝其他容器元素)
  list<int> l3(v.begin(),v.end());
  list<int> l4<l3>;
}
  

list iterator的使用

begin+end

begin指向第一个元素的迭代器,end指向最后一个位置的下一个位置的迭代器,作为迭代的结束标志。

cpp 复制代码
for(list<int>::iterator it=l.begin;it!=end();it++)
{
   *it*=2;
 }

rbegin+rend

rebegin指向最后一个元素的反向迭代器,rend指向第一个元素的前一个位置的反向迭代器。

cpp 复制代码
for (list<int>::reverse_iterator rit = l.rbegin(); rit != l.rend(); ++rit) 
    {
        cout << *rit << " ";
    }

list capacity

empty

检测list是否为空,如果为空,返回true,否则返回false。

size

返回list当中有效节点的个数

cpp 复制代码
cout<<l.size()<<endl;

list element access

front

返回list当中第一个结点值的引用

back

功能:返回 list 的最后一个节点中值的引用。

cpp 复制代码
cout<<l.front()<<endl;
cout<<l.back()<<endl;

list modifiers

push_front

在list首元素前插入值为val的元素

cpp 复制代码
l.push_front(1);

pop_front

在list首元素前删除值

cpp 复制代码
l.pop_front(1);

push_back

在 list 尾部插入值为 val 的元素

pop_back

在list尾部插入值为val的元素

insert

在list的目标位置插入值为val的元素

cpp 复制代码
l.insert(it,3);

erase

在list中删除值为val的元素

cpp 复制代码
auto it=l.begin();
++it;
++it;
l.erase(it);

swap

交换两个list的元素

cpp 复制代码
l1.swap(l2);

clear

清除list当中的有效元素

cpp 复制代码
l.clear();

list的迭代器失效

list是双向循环列表,节点在内存当中不连续。因此:

1插入操作不会导致迭代器失效

2删除操作仅被删除的节点的迭代器删除,其他节点迭代器不受影响

错误的示例:

cpp 复制代码
void test()
{
  int array[]={1,2,3,4};
  list<int> l(array,array+sizeof(array)/sizeof(array[0]);
  auto it=l.begin();
  while(it!=l.end())
  {
     l.erase(it);
     ++it;//对失效的迭代器自增,是未定义行为
   }
}

正确代码:

cpp 复制代码
l.erase(it++);//

原因:

it是用后自增,会先返回it的当前值,用于删除erase当前值,然后自动移动到下一个节点,避免使用失效的迭代器。

也可以显式使用erase的返回值更新:

cpp 复制代码
it=l.erase(it);

list的反向迭代器

反向迭代器的核心设计就是内部有一个正向迭代器_it。通过对正向迭代器的操作进行反转:

反向迭代器的++相当于反向迭代器的--;

反向迭代器的--相当于正向的++;

反向迭代器解引用时*访问的是正向迭代器前一个位置的元素。

相关推荐
数据皮皮侠AI4 分钟前
上市公司耐心资本数据(2010-2025)
大数据·人工智能·笔记·能源·1024程序员节
未若君雅裁20 分钟前
算法复杂度与数据结构:Java 集合篇的第一块基石
java·数据结构·算法
故事和你912 小时前
洛谷-【动态规划2】线性状态动态规划4
开发语言·数据结构·c++·算法·动态规划·图论
小欣加油3 小时前
leetcode 3300 替换为数位和后的最小元素
数据结构·c++·算法·leetcode
晚风予卿云月3 小时前
【枚举】普通枚举
数据结构·c++·算法·竞赛·算法随笔
不会就选b4 小时前
数据结构之顺序表
数据结构
z落落4 小时前
C# Hashtable 哈希表+SortedList 有序键值对集合
数据结构·散列表
Brilliantwxx4 小时前
【C++】 深入理解红黑树:实现与原理全解
数据结构·c++·笔记·算法·青少年编程·红黑树
Dlrb12114 小时前
数据结构-排序算法
数据结构·算法·排序算法·插入排序·堆排序·希尔排序·快速排序
过期动态4 小时前
【LeetCode 热题 100】无重复字符的最长子串
java·数据结构·spring boot·算法·leetcode·职场和发展