通俗易懂讲解 链表(原文出处)

1、单向链表

概念:

单向链表(单链表)是链表的一种,它由节点组成,每个节点都包含下一个节点的指针

示意图:

image.png

图解:

上图就是一个单链表,表头为空,表头的后继节点是”结点10”(数据为10的结点),”节点10”的后继结点是”节点20”(数据为10的结点),…

2、单链表删除节点

示例:

比如说下面这个单链表中我们要删除”节点30”。
image.png

图解:

删除之前:”节点20” 的后继节点为”节点30”,而”节点30” 的后继节点为”节点40”。
删除之后:”节点20” 的后继节点为”节点40”。

3、单链表添加节点

示例:

比如说下面这个单链表中我们在”节点10”与”节点20”之间添加”节点15”
image.png

图解:

添加之前:”节点10” 的后继节点为”节点20”。
添加之后:”节点10” 的后继节点为”节点15”,而”节点15” 的后继节点为”节点20”

4、双向链表

概念:

双向链表(双链表)是链表的一种。
和单链表一样,双链表也是由节点组成,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。一般我们都构造双向循环链表。

示意图:

image.png

图解:

表头为空,表头的后继节点为”节点10”(数据为10的节点);”节点10”的后继节点是”节点20”(数据为10的节点),”节点20”的前继节点是”节点10”;”节点20”的后继节点是”节点30”,”节点30”的前继节点是”节点20”;…;末尾节点的后继节点是表头。

5、双向链表删除节点

示例 :

下面这个单链表中我们要删除”节点30”

示意图:

image.png

图解:

删除之前:”节点20”的后继节点为”节点30”,”节点30” 的前继节点为”节点20”。”节点30”的后继节点为”节点40”,”节点40” 的前继节点为”节点30”。
删除之后:”节点20”的后继节点为”节点40”,”节点40” 的前继节点为”节点20”。

6、双向链表添加节点

示例:

比如说下面这个双向链表在”节点10”与”节点20”之间添加”节点15”

示意图:

image.png

图解:

添加之前:”节点10”的后继节点为”节点20”,”节点20” 的前继节点为”节点10”。
添加之后:”节点10”的后继节点为”节点15”,”节点15” 的前继节点为”节点10”。”节点15”的后继节点为”节点20”,”节点20” 的前继节点为”节点15”。