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是一个不错的选择。

相关推荐
cdut_suye3 分钟前
全面剖析 Linux 进程管理与 PCB 机制
java·linux·运维·服务器·c++·人工智能·python
仟濹6 分钟前
【算法 C/C++】二维前缀和
c语言·c++·算法
Chenyu_31011 分钟前
04.基于C++实现多线程TCP服务器与客户端通信
linux·服务器·网络·c++·tcp/ip·算法·visualstudio
音视频牛哥34 分钟前
C++20之2025年上桌我坐哪儿?
c++·编程语言·ai 编程
香菇滑稽之谈2 小时前
代理模式的C++实现示例
c++·设计模式·系统安全·代理模式
Dante7982 小时前
【数据结构】二叉搜索树、平衡搜索树、红黑树
数据结构·c++·算法
奕天者2 小时前
C++学习笔记(十七)——类之封装
c++·笔记·学习
Ljw...3 小时前
序列化和反序列化(Linux)
linux·开发语言·网络·c++·tcp/ip·序列化反序列化
lucky1_1star3 小时前
FX-函数重载、重写(覆盖)、隐藏
java·c++·算法
UestcXiye3 小时前
《TCP/IP网络编程》学习笔记 | Chapter 17:优于 select 的 epoll
c++·网络编程