<数据结构> 链表 - 链表的概念及结构

Posted 徐徐同学

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了<数据结构> 链表 - 链表的概念及结构相关的知识,希望对你有一定的参考价值。

A.链表的概念及结构

1、 链表的概念

概念:链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的

1、链表由一系列结点(链表中每一个元素称为结点)组成。

2、结点可以在运行时动态(malloc)生成。

3、每个结点包括两个部分:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域(详见1.2 节点部分)。

4、相比于线性表顺序结构,链表操作复杂。但是由于不需按顺序存储,链表在插入的时候可以达到O(1)的复杂度,比顺序表快得多;但是查找一个节点或者访问特定编号的节点则需要O(n)的时间,而顺序表只需O(1)

2、 结点

链表由一个个结点构成,每个结点采用结构体的形式。结构体内前面的变量按照需要给予,最后一个变量是这个结构体类型的指针,用来存放下一节点的首地址‘

链表结点分为两个
数据域 :存放各种实际的数据
指针域 :存放下一结点的地址
(图为带哨兵位头结点的链表)

3、 链表的使用场景

线性表在 需要经常插入或删除数据元素 的情况下适合采用链式存储结构。

因为对于链表来说,插入或删除数据只需要创建一个结点、输入数据、修改指针把该结点连接到链表中的某一位置即可; 而对于顺序表,插入一个数据可能需要搬移其他数据,复杂度高。

4、 链表分类 和 常用的结构

各种链表的结构:

虽然组合起来一共有8种链表可以选择,但是实际中最常用的主要还是 无头单向非循环 链表和 带头双向循环 链表。

1、无头单向非循环链表:俗称 “单链表”。结构简单,一般不会单独用来存储数据。实际上更多是作为其他数据结构的子结构(如哈希桶、图的邻接表、栈的链式结构等)

2、带头双向循环链表结构最复杂,一般用来单独存储数据。实际使用的链表,大多都是带头双向循环链表。虽然结构最复杂,但是这种结构会带来很多优势。

5、 与顺序表的比较

链表: 链表是通过结点把离散的数据链接成一个表,通过对结点的插入、删除操作从而实现对数据的存取。

顺序表: 顺序表是通过开辟一段连续的内存(直接使用 数组 或者 malloc后realloc扩容)来存储数据。

但是由于 realloc 扩容分为原地扩容和异地扩容,前者代价较低,而后者扩容时不仅需要拷贝数据,还要释放旧空间。再者,扩容时一般会扩到原来容量的2倍,扩容次数多了就容易造成空间的浪费

顺序表的每个成员对应链表的结点;成员和结点的数据类型可以是标准的c类型或者是用户自定义的结构体类型。

比较对象顺序表链表
存储空间连续不连续
插入或删除数据可能要搬移数据,复杂度O(n)只需修改指针
push动态顺序表:空间不够了需要扩容没有“容量”的概念,push时直接malloc新的结点
应用需要频繁访问需要频繁插入、删除数据

数据结构---线性表(链表)

链表



链表的概念及结构

概念:链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的 。
链表中的数据, 包含了数据的本身, 也包含下一个数据的指针的指向, 所以它本身也是一种新的类型
在这里插入图片描述

因为链表中的数据在内存中的存放是不连续的, 所以数据不仅包含数据本身还有一个指针的指向, 如果没有指针, 那这个数据就找不到.
它是一个逻辑上连续的, 物理上不连续的结构
实际中链表的结构非常多样,以下情况组合起来就有8种链表结构:

  1. 单向、双向
  2. 带头、不带头 (第一个节点能不能存放有效的数据)
  3. 循环、非循环

单链表(无头单向非循环链表)

1, 无头单向非循环链表:结构简单,一般不会单独用来存数据。实际中更多是作为其他数据结构的子结构,如哈希桶、图的邻接表等等。

在这里插入图片描述
在这里插入图片描述

链表的实现

1.初始化链表
在这里插入图片描述
2.创建节点
在这里插入图片描述
3.尾插
在这里插入图片描述
在这里插入图片描述
链表的尾插先对比较麻烦, 需要遍历整个链表是一个O(n)的时间复杂度
4.尾删
在这里插入图片描述
在这里插入图片描述
5.头插
在这里插入图片描述
6.给某一个节点的后面插入一个数据
在这里插入图片描述
7.删除某个节点后面的数据
在这里插入图片描述
8.查找
在这里插入图片描述
9.释放
在这里插入图片描述
在这里插入图片描述

以上是关于<数据结构> 链表 - 链表的概念及结构的主要内容,如果未能解决你的问题,请参考以下文章

C语言链表

数据结构---线性表(链表)

数据结构--单链表的实现(c语言实现)

数据结构--单链表的实现(c语言实现)

数据结构(链表——双向链表的实现)

数组链表的概念及区别