教育改变生活

标题: 【数据结构】双链表 [打印本页]

作者: wander    时间: 2023-6-12 16:27
标题: 【数据结构】双链表
本帖最后由 wander 于 2023-6-12 16:29 编辑

      虽然使用单链表能 100% 解决逻辑关系为 "一对一" 数据的存储问题,但在解决某些特殊问题时,单链表并不是效率最优的存储结构。比如说,如果算法中需要大量地找某指定结点的前趋结点,使用单链表无疑是灾难性的,因为单链表更适合 "从前往后" 找,而 "从后往前" 找并不是它的强项。
为了能够高效率解决类似的问题,可以采用双链表来实现。
从名字上理解双向链表,即链表是 "双向" 的,指的是各节点之间的逻辑关系是双向的,但通常头指针只设置一个,除非实际情况需要。如图 1 所示:


图 1 双向链表结构示意图

从图 1 中可以看到,双向链表中各节点包含以下 3 部分信息(如图 2 所示):


图 2 双向链表的节点构成


因此,双链表的节点结构为:

双向链表的创建同单链表相比,双链表仅是各节点多了一个用于指向直接前驱的指针域。因此,我们可以在单链表的基础轻松实现对双链表的创建。
需要注意的是,与单链表不同,双链表创建过程中,每创建一个新节点,都要与其前驱节点建立两次联系,分别是:
创建双向链表的代码:

双向链表添加节点
根据数据添加到双向链表中的位置不同,可细分为以下 3 种情况:
添加至表头
  将新数据元素添加到表头,只需要将该元素与表头元素建立双层逻辑关系即可。
换句话说,假设新元素节点为 temp,表头节点为 head,则需要做以下 2 步操作即可:
例如,将新元素 7 添加至双链表的表头,则实现过程如图 2 所示:


图 2 添加元素至双向链表的表头

添加至表的中间位置
同单链表添加数据类似,双向链表中间位置添加数据需要经过以下 2 个步骤,如图 3 所示:


图 3 双向链表中间位置添加数据元素

添加至表尾
与添加到表头是一个道理,实现过程如下(如图 4 所示):


图 4 双向链表尾部添加数据元素


因此,我们可以试着编写双向链表添加数据的代码,参考代码如下:

双向链表删除节点
双链表删除结点时,只需遍历链表找到要删除的结点,然后将该节点从表中摘除即可。
例如,从图 1 基础上删除元素 2 的操作过程如图 5 所示:



图 5 双链表删除元素操作示意图


双向链表删除节点的代码如下:


双向链表查找节点
通常,双向链表同单链表一样,都仅有一个头指针。因此,双链表查找指定元素的实现同单链表类似,都是从表头依次遍历表中元素。
实现代码为:

双向链表更改节点
更改双链表中指定结点数据域的操作是在查找的基础上完成的。实现过程是:通过遍历找到存储有该数据元素的结点,直接更改其数据域即可。

实现此操作的 C 语言实现代码如下:









欢迎光临 教育改变生活 (http://bbs.goldoar.com/) Powered by Discuz! X3.2