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

相关推荐
雾削木23 分钟前
mAh 与 Wh:电量单位的深度解析
开发语言·c++·单片机·嵌入式硬件·算法·电脑
Ethon_王2 小时前
走进Qt--工程文件解析与构建系统
c++·qt
工藤新一¹3 小时前
C++/SDL进阶游戏开发 —— 双人塔防游戏(代号:村庄保卫战 13)
c++·游戏·游戏引擎·毕业设计·sdl·c++游戏开发·渲染库
让我们一起加油好吗3 小时前
【C++】类和对象(上)
开发语言·c++·visualstudio·面向对象
好想有猫猫3 小时前
【Redis】服务端高并发分布式结构演进之路
数据库·c++·redis·分布式·缓存
不是杠杠3 小时前
驼峰命名法(Camel Case)与匈牙利命名法(Hungarian Notation)详解
c++
Epiphany.5564 小时前
基于c++的LCA倍增法实现
c++·算法·深度优先
落羽的落羽4 小时前
【落羽的落羽 C++】vector
c++
newki4 小时前
学习笔记,Linux虚拟机中C/C++的编译相关流程步骤
c语言·c++
jerry6094 小时前
c++流对象
开发语言·c++·算法