C++ List

C++11中的std::list是一种双向链表容器。在底层,std::list的每个元素都被包装在一个节点内,每个节点包括一个指向前一个节点的指针、一个指向后一个节点的指针以及元素本身。

下面是std::list常用的功能及示例:

  1. 插入元素
cpp 复制代码
#include <iostream>
#include <list>

int main() {
    std::list<int> mylist = {1, 2, 3};
    
    // 在头部插入元素
    mylist.push_front(0);
    
    // 在尾部插入元素
    mylist.push_back(4);

    // 在指定位置插入元素
    auto it = mylist.begin();
    ++it; // 指向第二个元素
    mylist.insert(it, 5);
    
    for (const auto& elem : mylist) {
        std::cout << elem << " ";
    }
    
    return 0;
}
  1. 删除元素
cpp 复制代码
#include <iostream>
#include <list>

int main() {
    std::list<int> mylist = {1, 2, 3, 4, 5};
    
    // 删除头部元素
    mylist.pop_front();
    
    // 删除尾部元素
    mylist.pop_back();
    
    // 删除指定位置的元素
    auto it = mylist.begin();
    ++it; // 指向第二个元素
    mylist.erase(it);
    
    for (const auto& elem : mylist) {
        std::cout << elem << " ";
    }
    
    return 0;
}
  1. 遍历列表
cpp 复制代码
#include <iostream>
#include <list>

int main() {
    std::list<int> mylist = {1, 2, 3, 4, 5};
    
    for (auto it = mylist.begin(); it != mylist.end(); ++it) {
        std::cout << *it << " ";
    }
    
    return 0;
}
  1. 反向遍历列表
cpp 复制代码
#include <iostream>
#include <list>

int main() {
    std::list<int> mylist = {1, 2, 3, 4, 5};
    
    for (auto it = mylist.rbegin(); it != mylist.rend(); ++it) {
        std::cout << *it << " ";
    }
    
    return 0;
}

std::list提供了高效的插入和删除操作,但随机访问速度较慢。在需要频繁在中间插入或删除元素时,std::list是一个不错的选择。

相关推荐
利刃大大4 小时前
【高并发内存池】五、页缓存的设计
c++·缓存·项目·内存池
C语言小火车5 小时前
【C++八股文】基础知识篇
c++·tcp/ip·const·智能指针·多线程同步·static关键字·c++内存模型
liulilittle5 小时前
IP校验和算法:从网络协议到SIMD深度优化
网络·c++·网络协议·tcp/ip·算法·ip·通信
眠りたいです5 小时前
基于脚手架微服务的视频点播系统-播放控制部分
c++·qt·ui·微服务·云原生·架构·播放器
Want5956 小时前
C/C++圣诞树①
c语言·开发语言·c++
老赵的博客6 小时前
c++ 杂记
开发语言·c++
jimmy.hua6 小时前
[C++刷怪笼]:set/map--优质且易操作的容器
开发语言·c++
tan180°6 小时前
Boost搜索引擎 网络库与前端(4)
linux·网络·c++·搜索引擎
bkspiderx7 小时前
C++经典的数据结构与算法之经典算法思想:贪心算法(Greedy)
数据结构·c++·算法·贪心算法
郝学胜-神的一滴7 小时前
避免使用非const全局变量:C++中的最佳实践 (C++ Core Guidelines)
开发语言·c++·程序人生