c++中的链表list

前言

c++里面的list容器,真的是链表实现,中间元素的插入和删除是 O ( 1 ) O(1) O(1) 时间复杂度的。有必要了解一下它的基本用法。

代码

cpp 复制代码
#include <list>
#include <iostream>


using namespace std;


int main()
{
    list<int> lst{1,3,4,2};
    auto it  = lst.begin();
    it++;

    // 插入元素
    lst.insert(it, {20,30,40}); // 插入到第2个位置
    for(auto item : lst) cout << item << " "; cout << endl; /*[ 1 20 30 40 3 4 2 ]*/

    // 按位置删除元素
    it =  lst.begin();
    advance(it, 1); // 删除第2个元素
    lst.erase(it); 
    for(auto item : lst) cout << item << " "; cout << endl; /*[ 1 30 40 3 4 2 ]*/


    // 按值删除元素
    lst.remove(2); // 删除所有为2的元素
    for(auto item : lst) cout << item << " "; cout << endl; /*[ 1 30 40 3 4 ]*/


    return 0;
}

结果

复制代码
1 20 30 40 3 4 2 
1 30 40 3 4 2
1 30 40 3 4
相关推荐
一拳一个呆瓜1 小时前
【STL】_SCL_SECURE_NO_WARNINGS
c++·stl
小小编程路1 小时前
C++ 异常 完整讲解
开发语言·c++
Frank学习路上4 小时前
【C++】面试:关键字与语法特性
c++·面试
liulilittle4 小时前
固定数组时间轮的槽过载优化:桶链表与批次执行
网络·数据结构·链表
Irissgwe5 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列
点云侠6 小时前
PCL 生成三棱锥点云
c++·算法·最小二乘法
.道阻且长.6 小时前
C++ string 操作指南:接口解析
java·c语言·开发语言·c++
laplaya7 小时前
使用 vcpkg 管理 C++ 项目中的依赖
开发语言·c++
blueman88888 小时前
VS2022 切换定义(F12 / Go to Definition)反应慢
c++·visual studio
凡人叶枫8 小时前
Effective C++ 条款35:考虑 virtual 函数以外的其他选择
java·c++·spring