【数据结构与算法】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缓存、跳表等更高级数据结构的基础,也是面试与考研中高频考察的核心知识点。

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

相关推荐
烬羽2 分钟前
从零理解树与二叉树:用 JS 带你手撕遍历和递归
javascript·数据结构
Zella折耳根2 分钟前
复习篇-继承和接口
java·开发语言·python
z落落5 分钟前
C# 事件(Event)+自定义带参数事件例子
开发语言·分布式·c#
FlYFlOWERANDLEAF5 分钟前
DevExpress Office File API使用记录
开发语言·c#·devoffice
程序员二叉8 分钟前
【JVM】OOM详解+JVM参数+FullGC排查+CPU飙高+死锁+内存泄漏+命令大全
java·开发语言·jvm·面试
YHL11 分钟前
🚀从零理解树与二叉树 —— 概念、实现与遍历
前端·javascript·数据结构
yijianace20 分钟前
Python线程与多线程完全总结(从入门到理解并发本质)
开发语言·python
不知名的老吴27 分钟前
线程的生命周期之线程同步
java·开发语言·jvm
JieE21240 分钟前
JS 到底有多少种数据类型?从ECMA规范到内存本质,一文彻底搞懂
javascript·数据结构·面试
努力努力再努力wz1 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表