首页 > 其他分享 >List详解 - 双向链表的操作

List详解 - 双向链表的操作

时间:2025-01-10 22:29:34浏览次数:3  
标签:std 变为 myList List 元素 list 链表 详解

在C++中,std::list是标准模板库(STL)中的一个容器,它实现了双向链表的数据结构。与数组或向量(std::vector)不同,std::list允许在常数时间内进行插入和删除操作,尤其是在链表的任意位置。本文将详细介绍std::list的基本操作,并通过示例代码帮助读者理解其使用方法。

1. std::list 的基本概念

std::list是一个双向链表,每个元素都包含两个指针,分别指向前一个和后一个元素。这种结构使得在链表中插入和删除元素非常高效,但访问元素的速度较慢,因为需要从头或尾开始遍历。

1.1 头文件

要使用std::list,首先需要包含头文件:

#include <list>

1.2 定义和初始化

std::list的定义和初始化方式与其他STL容器类似:

std::list<int> myList;  // 定义一个空的int类型链表
std::list<int> myList2 = {1, 2, 3, 4, 5};  // 定义并初始化一个链表

2. std::list 的基本操作

2.1 插入元素

std::list提供了多种插入元素的方法:

  • push_back():在链表末尾插入元素。
  • push_front():在链表开头插入元素。
  • insert():在指定位置插入元素。
std::list<int> myList = {1, 2, 3};

myList.push_back(4);  // 链表变为 {1, 2, 3, 4}
myList.push_front(0); // 链表变为 {0, 1, 2, 3, 4}

auto it = myList.begin();
std::advance(it, 2);  // 将迭代器移动到第三个元素
myList.insert(it, 10); // 链表变为 {0, 1, 10, 2, 3, 4}

2.2 删除元素

std::list也提供了多种删除元素的方法:

  • pop_back():删除链表末尾的元素。
  • pop_front():删除链表开头的元素。
  • erase():删除指定位置的元素。
  • remove():删除所有等于指定值的元素。
std::list<int> myList = {0, 1, 10, 2, 3, 4};

myList.pop_back();  // 链表变为 {0, 1, 10, 2, 3}
myList.pop_front(); // 链表变为 {1, 10, 2, 3}

auto it = myList.begin();
std::advance(it, 1);  // 将迭代器移动到第二个元素
myList.erase(it);     // 链表变为 {1, 2, 3}

myList.remove(2);     // 链表变为 {1, 3}

2.3 访问元素

由于std::list是双向链表,不支持随机访问。要访问元素,必须使用迭代器:

std::list<int> myList = {1, 2, 3, 4, 5};

for (auto it = myList.begin(); it != myList.end(); ++it) {
    std::cout << *it << " ";  // 输出: 1 2 3 4 5
}

2.4 链表的大小和清空

  • size():返回链表中元素的数量。
  • empty():检查链表是否为空。
  • clear():清空链表中的所有元素。
std::list<int> myList = {1, 2, 3};

std::cout << "Size: " << myList.size() << std::endl;  // 输出: Size: 3
std::cout << "Is empty? " << myList.empty() << std::endl;  // 输出: Is empty? 0

myList.clear();  // 清空链表
std::cout << "Is empty? " << myList.empty() << std::endl;  // 输出: Is empty? 1

2.5 链表的排序和反转

  • sort():对链表中的元素进行排序。
  • reverse():反转链表中的元素顺序。
std::list<int> myList = {3, 1, 4, 1, 5, 9};

myList.sort();  // 链表变为 {1, 1, 3, 4, 5, 9}
myList.reverse();  // 链表变为 {9, 5, 4, 3, 1, 1}

3. std::list 的高级操作

3.1 合并链表

std::list提供了merge()方法,用于合并两个已排序的链表:

std::list<int> list1 = {1, 3, 5};
std::list<int> list2 = {2, 4, 6};

list1.merge(list2);  // list1 变为 {1, 2, 3, 4, 5, 6}, list2 变为空

3.2 拼接链表

std::listsplice()方法可以将一个链表的部分或全部元素移动到另一个链表中:

std::list<int> list1 = {1, 2, 3};
std::list<int> list2 = {4, 5, 6};

auto it = list1.begin();
std::advance(it, 1);  // 将迭代器移动到第二个元素
list1.splice(it, list2);  // list1 变为 {1, 4, 5, 6, 2, 3}, list2 变为空

3.3 去重

std::listunique()方法可以删除链表中连续的重复元素:

std::list<int> myList = {1, 1, 2, 3, 3, 3, 4};

myList.unique();  // 链表变为 {1, 2, 3, 4}

4. 总结

std::list是C++中一个非常强大的容器,特别适合需要频繁插入和删除操作的场景。通过本文的介绍,读者应该能够掌握std::list的基本操作和高级功能。在实际编程中,合理使用std::list可以大大提高代码的效率和可读性。

希望本文对你理解和使用std::list有所帮助!如果你有任何问题或建议,欢迎在评论区留言讨论。

标签:std,变为,myList,List,元素,list,链表,详解
From: https://blog.csdn.net/2301_81482480/article/details/145066468

相关文章

  • CPP-Net模型详解
    模型背景在细胞核分割领域,早期的研究主要依赖于基于形状模型和基于图割的方法。这些传统方法虽然能在一定程度上解决问题,但存在显著局限性:基于形状模型的方法需要预先定义形状模板,难以适应多样化的细胞核形态;基于图割的方法虽能较好处理重叠细胞核,但计算复杂度高,运......
  • LeetCode:141.环形链表
    //双指针快+1=慢trueclassListNode{constructor(val,next){this.val=(val===undefined?0:val)this.next=(next===undefined?null:next)}}varhasCycle=function(head){letfast=headletslow=headwhile(......
  • LeetCode:83.删除排序链表中的重复元素
    LeetCode:83.删除排序链表中的重复元素classListNode{constructor(val,next){this.val=(val===undefined?0:val)this.next=(next===undefined?null:next)}}vardeleteDuplicates=function(head){letp=head//head......
  • 【C++】揭开C++类与对象的神秘面纱(首卷)(类的基础操作详解、实例化艺术及this指针的深
    文章目录一、类的定义1.类定义格式2.类访问限定符3.类域二、类的实例化1.实例化概念2.对象的大小三、隐藏的this指针与相关练习1.this指针的引入与介绍练习1练习2练习3一、类的定义1.类定义格式   在讲解类的作用之前,我们来看看类是如何定义的,在C++中,class......
  • 详解:订单履约系统规划
    大家好,我是汤师爷~什么是订单履约系统?订单履约是从消费者下单支付到收到商品的全流程管理过程,包括订单接收、订单派单、库存分配、仓储管理和物流配送等环节,核心目标是确保商品准时、准确地送达消费者手中。通过订单履约系统,消费者可以实时了解商品的物流状态和预计送达时间,并......
  • Blazor用户身份验证状态详解
        在Blazor应用程序中,AuthenticationState是一个核心概念,用于表示用户的身份验证状态。它提供有关当前用户的信息,例如是否已登录、用户的身份信息(如用户名、角色等)。AuthenticationState通常由AuthenticationStateProvider提供,Blazor使用它来管理和传播用户......
  • 力扣21、合并两个有序链表
    目录1、题目2、思路3、代码若有错误,欢迎指正! 1、题目将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例1:输入:l1=[1,2,4],l2=[1,3,4]输出:[1,1,2,3,4,4]示例2:输入:l1=[],l2=[]输出:[]示例......
  • 详解 C++ 防御性编程声明一个类型 int *(*(*foo)(int))[5];
    C++中有一些语法由于灵活性和强大功能显得非常复杂。例如,复杂声明是许多人在学习C++时遇到的难题之一。下面以一条常被称为“C++最难的声明”为例,逐步拆解它的含义。声明:int*(*(*foo)(int))[5];这是一个看似复杂的C++声明。让我们逐步分析它的含义。1.阅读......
  • 数据结构——单链表(C语言版:超详细)
    目录一、引言1.数据结构的重要性2.单链表在其中的地位二、什么是单链表1.单链表的定义2.基本概念解释三、单链表的结构特点1.与数组对比的优势2.存在的劣势四、单链表的基本操作1.节点的创建2.动态申请一个节点3.插入节点3.1尾插3.2头插3.3在pos之前插入3.4在......
  • 专业无人机飞手培训,考证、组装、调参、维修全面技术详解
    专业无人机飞手培训是一个系统而全面的过程,涵盖了考证、组装、调参、维修等多个方面。以下是对这些技术的详细解析:一、考证1.必要性法规要求:根据《民用无人驾驶航空器系统驾驶员管理暂行规定》等相关法规,超出一定重量、飞行范围和用途的无人机需要飞手持有相应的执照,这是......