数据结构与算法——什么是线性表(线性存储结构)

我们知道,具有"一对一"逻辑关系的数据,最佳的存储方式是使用线性表。那么,什么是线性表呢?

线性表,全名为线性存储结构。使用线性表存储数据的方式可以这样理解,即"把所有数据用一根线儿串起来,再存储到物理空间中"。
图 1 "一对一"逻辑关系的数据

如图 1 所示,这是一组具有"一对一"关系的数据,我们接下来采用线性表将其储存到物理空间中。

首先,用"一根线儿"把它们按照顺序"串"起来,如图 2 所示:
图 2 数据的"线性"结构

图 2 中,左侧是"串"起来的数据,右侧是空闲的物理空间。把这"一串儿"数据放置到物理空间,我们可以选择以下两种方式,如图 3 所示。
图 3 两种线性存储结构

图 3a) 是多数人想到的存储方式,而图 3b) 却少有人想到。我们知道,数据存储的成功与否,取决于是否能将数据完整地复原成它本来的样子。如果把图 3a) 和图 3b) 线的一头扯起,你会发现数据的位置依旧没有发生改变(和图 1 一样)。因此可以认定,这两种存储方式都是正确的。

将具有"一对一"关系的数据"线性"地存储到物理空间中,这种存储结构就称为线性存储结构(简称线性表)。

使用线性表存储的数据,如同向数组中存储数据那样,要求数据类型必须一致,也就是说,线性表存储的数据,要么全部都是整形,要么全部都是字符串。一半是整形,另一半是字符串的一组数据无法使用线性表存储。

顺序存储结构和链式存储结构

图 3 中我们可以看出,线性表存储数据可细分为以下 2 种:

  1. 如图 3a) 所示,将数据依次存储在连续的整块物理空间中,这种存储结构称为顺序存储结构(简称顺序表);
  2. 如图 3b) 所示,数据分散的存储在物理空间中,通过一根线保存着它们之间的逻辑关系,这种存储结构称为链式存储结构(简称链表);

也就是说,线性表存储结构可细分为顺序存储结构和链式存储结构。

前驱和后继

数据结构中,一组数据中的每个个体被称为"数据元素"(简称"元素")。例如,图 1 显示的这组数据,其中 1、2、3、4 和 5 都是这组数据中的一个元素。

另外,对于具有"一对一"逻辑关系的数据,我们一直在用"某一元素的左侧(前边)或右侧(后边)"这样不专业的词,其实线性表中有更准确的术语:

  • 某一元素的左侧相邻元素称为"直接前驱",位于此元素左侧的所有元素都统称为"前驱元素";
  • 某一元素的右侧相邻元素称为"直接后继",位于此元素右侧的所有元素都统称为"后继元素";

以图 1 数据中的元素 3 来说,它的直接前驱是 2 ,此元素的前驱元素有 2 个,分别是 1 和 2;同理,此元素的直接后继是 4 ,后继元素也有 2 个,分别是 4 和 5。如图 4 所示:
图4 前驱和后继

2023新版数据结构与算法Java视频教程(上篇),java高级程序员必学的数据结构与算法
2023新版数据结构与算法Java视频教程(下篇),java高级程序员必学的数据结构与算法

相关推荐
向宇it2 分钟前
【unity小技巧】Unity 四叉树算法实现空间分割、物体存储并进行查询和碰撞检测
开发语言·算法·游戏·unity·游戏引擎
无限大.2 分钟前
冒泡排序(结合动画进行可视化分析)
算法·排序算法
走向自由22 分钟前
Leetcode 最长回文子串
数据结构·算法·leetcode·回文·最长回文
nuo53420237 分钟前
The 2024 ICPC Kunming Invitational Contest
c语言·数据结构·c++·算法
luckilyil37 分钟前
Leetcode 每日一题 11. 盛最多水的容器
算法·leetcode
特种加菲猫43 分钟前
初阶数据结构之队列的实现
开发语言·数据结构·笔记
A.A呐1 小时前
LeetCode 1658.将x减到0的最小操作数
算法·leetcode
hn小菜鸡1 小时前
LeetCode 144.二叉树的前序遍历
算法·leetcode·职场和发展
rubyw1 小时前
如何选择聚类算法、回归算法、分类算法?
算法·机器学习·分类·数据挖掘·回归·聚类
编程探索者小陈1 小时前
【优先算法】专题——双指针
数据结构·算法·leetcode