【数据结构与算法】C语言实现双向链表 (Double Linked List) 全解析

一、什么是双向链表?

  1. 核心定义

双向链表是一种线性表,它的每个数据节点不仅存储了指向下一个节点的指针 next ,还多了一个指向前一个节点的指针 prev 。

这意味着:

  • 单链表:只能从头走到尾(单向)。

  • 双向链表:可以从头走到尾,也可以从尾走到头(双向)。

  1. 节点结构 (Node Structure)

每个节点包含三个部分:

  1. prev :前驱指针,指向前一个节点。

  2. val / data :存储的数据。

  3. next :后继指针,指向后一个节点。

在 C 语言中定义如下:

二、双向链表 vs 单链表:优缺点对比

表格
结论:在对插入、删除操作频繁,且需要双向遍历的场景中,双向链表是首选。

三、六大核心操作详解

  1. 基础工具:创建新节点
  2. 核心操作一:头插法 (Push Front)

原理:新节点成为新的头,它的 next 指向旧头,旧头的 prev 指向新节点。

  1. 核心操作二:尾插法 (Push Back)

原理:找到链表尾部,将尾部节点的 next 指向新节点,新节点的 prev 指向尾部节点。

  1. 核心操作三:头删法 (Pop Front)

原理:删除头节点,将新头节点的 prev 置为 NULL 。

  1. 核心操作四:尾删法 (Pop Back)

原理:找到尾节点,将其前驱节点的 next 置为 NULL ,然后释放尾节点。

  1. 核心操作五:指定位置插入 (Insert After)

场景:在某个指定节点 pos 的后面插入新节点。

  1. 核心操作六:指定位置删除 (Delete Node)

场景:删除链表中指定的某个节点 delNode 。

四、辅助函数:打印与释放

五、核心算法:反转双向链表

六、主函数:测试所有功能

七、运行结果

八、深度总结:双向链表的精髓

  1. 永远先保存:在修改指针前,务必用临时变量保存可能丢失的节点地址,避免链表断裂。

  2. 双向更新:插入/删除操作时,要同时更新 prev 和 next 指针,保证双向指向正确。

  3. 边界检查:必须处理链表为空、只有一个节点等边界情况,防止空指针访问。

  4. 内存管理:删除节点后要及时释放内存,避免内存泄漏。

九、总结

双向链表是在单链表基础上扩展出的高效线性表结构,核心思想是为每个节点增加 prev 前驱指针,实现双向遍历与更灵活的操作。

它最大的优势是插入、删除操作效率更高(无需遍历查找前驱节点),支持双向遍历;最大的代价是额外占用一个指针的存储空间,空间复杂度略高于单链表。

掌握双向链表,是深入学习循环链表、LRU缓存、跳表等更高级数据结构的基础,也是面试与考研中高频考察的核心知识点。

如果这篇文章对你有帮助,欢迎点赞、收藏、关注,后续会持续更新数据结构与算法干货,我们一起进步!🚀

相关推荐
heimeiyingwang3 小时前
【架构实战】系统设计面试题精选
java·开发语言·架构
AlenTech3 小时前
142. 环形链表 II - 力扣(LeetCode)
数据结构·leetcode·链表
剑心诀3 小时前
【C语言 数据结构】易错题集
c语言·数据结构·算法
我能坚持多久3 小时前
【初阶数据结构12】——C语言实现八大排序算法与代码深度解析
c语言·数据结构·排序算法
Ulyanov3 小时前
基于ttk的Python现代化GUI开发指南
开发语言·前端·python·tkinter·系统设计
枫叶丹43 小时前
【HarmonyOS 6.0】Telephony Kit 新能力:精准获取卡槽ID与SIM卡对应关系
开发语言·华为·harmonyos
旺仔.2913 小时前
顺序容器:list双向链表 详解
数据结构·c++·链表·list
不会写DN3 小时前
PHP mysqli 实用开发指南
android·开发语言·php
Evand J3 小时前
【MATLAB例程】多无人机协同巡逻仿真:基于长机-僚机模型的编队保持与串级PID控制
开发语言·matlab·无人机·控制·pid·串级pid