【C++】std::forward_list

std::forward_list:

std::forward_list 是 C++ 标准库中的一个单向链表容器。与 std::list 相比,std::forward_list 只允许单向遍历,即只能从前往后访问元素。它的实现比 std::list 更轻量,因此在内存和性能方面通常更优,但缺少双向访问的能力。

特性

  1. 单向链表 : std::forward_list 只包含指向下一个元素的指针,不包含指向前一个元素的指针。
  2. 非随机访问 : 与 std::list 相同,不支持通过下标访问元素。
  3. 动态大小: 容器大小可以动态调整。
  4. 稳定的迭代器: 除了被删除的迭代器,其余迭代器在插入和删除操作后保持有效。

常用操作

1. 创建和初始化
cpp 复制代码
#include <forward_list>
#include <iostream>

int main() {
    // 创建一个空的 forward_list
    std::forward_list<int> fwd_lst1;

    // 创建一个初始化为 5 个元素的 forward_list,元素值为 10
    std::forward_list<int> fwd_lst2(5, 10);

    // 使用初始化列表创建 forward_list
    std::forward_list<int> fwd_lst3 = {1, 2, 3, 4, 5};

    return 0;
}
2. 访问和修改元素
cpp 复制代码
#include <forward_list>
#include <iostream>

int main() {
    std::forward_list<int> fwd_lst = {1, 2, 3, 4, 5};

    // 使用迭代器遍历 forward_list
    for (auto it = fwd_lst.begin(); it != fwd_lst.end(); ++it) {
        std::cout << *it << " ";
    }
    std::cout << std::endl;

    // 修改元素
    auto it = fwd_lst.begin();
    ++it; // 移动到第二个元素
    *it = 20;

    std::cout << "Modified list: ";
    for (const auto& elem : fwd_lst) {
        std::cout << elem << " ";
    }
    std::cout << std::endl;

    return 0;
}

3. 添加和删除元素:

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

int main() {
    std::forward_list<int> fwd_lst = {1, 2, 3, 4, 5};

    // 在前面添加元素
    fwd_lst.push_front(0);

    // 删除前面元素
    fwd_lst.pop_front();

    std::cout << "List after push and pop operations: ";
    for (const auto& elem : fwd_lst) {
        std::cout << elem << " ";
    }
    std::cout << std::endl;

    return 0;
}

4. 插入和删除指定位置的元素

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

int main() {
    std::forward_list<int> fwd_lst = {1, 2, 3, 4, 5};

    // 插入元素
    auto it = fwd_lst.before_begin(); // 指向第一个元素的前面
    fwd_lst.insert_after(it, 10); // 在第一个元素前插入 10

    // 删除指定位置的元素
    it = fwd_lst.begin();
    fwd_lst.erase_after(it); // 删除第一个元素

    std::cout << "List after insert and erase operations: ";
    for (const auto& elem : fwd_lst) {
        std::cout << elem << " ";
    }
    std::cout << std::endl;

    return 0;
}
5. 其他常用方法
  • size() : 返回 forward_list 中元素的数量。
  • empty() : 判断 forward_list 是否为空。
  • clear() : 清空 forward_list 中的所有元素。
  • front() : 访问 forward_list 的第一个元素。
  • resize() : 不适用于 forward_list,因为不支持随机访问。
相关推荐
m0_738120728 分钟前
CTFshow系列——命令执行web38-40
前端·windows·安全·web安全
程序设计实验室5 小时前
在Windows上将git与ssh-agent搭配使用,再也不用输入git密码了
windows·git
海天胜景18 小时前
编译器错误消息: CS0016: 未能写入输出文件“c:\Windows\Microsoft.NET... 拒绝访问
c语言·windows
搏博1 天前
基于Python3.10.6与jieba库的中文分词模型接口在Windows Server 2022上的实现与部署教程
windows·python·自然语言处理·flask·中文分词
有梦想的攻城狮1 天前
Java 11中的Collections类详解
java·windows·python·java11·collections
忒可君1 天前
C# winform FTP功能
开发语言·windows·c#
十五年专注C++开发2 天前
CMake进阶: CMake Modules---简化CMake配置的利器
linux·c++·windows·cmake·自动化构建
degree5202 天前
全平台轻量浏览器推荐|支持Win/macOS/Linux,极速加载+隐私保护+扩展插件,告别广告与数据追踪!
windows·macos·电脑
许泽宇的技术分享2 天前
Windows桌面自动化的革命性突破:深度解析Windows-MCP.Net Desktop模块的技术奥秘
windows·自动化·.net
七仔的博客3 天前
【摸鱼办公神器】七仔的桌面工具超进化 -> 灵卡面板 v1.1.9
windows·神器·摸鱼