线性表

具有“一对一”逻辑关系的数据,最佳的存储方式就是使用线性表。
线性表概述: 全名为线性存储结构。可以理解为“把所有数据用一根线串起来。再存储到物理空间中”。
一组1对1逻辑关系的数据如下:
         1 2 3 4 5

首先,用“一根线儿”把它们按照顺序“串”起来,如下图1 所示:
在这里插入图片描述
上图中,左侧是“串”起来的数据,右侧是空闲的物理空间。把这“一串儿”数据放置到物理空间,我们可以选择以下两种方式,如下图2 所示。

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

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

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

线性表存储结构可细分为顺序存储结构和链式存储结构。
图2中我们可以看出,线性表存储数据可细分为以下 2 种:

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

前驱和后继:
数据结构中,一组数据中的每个个体被称为“数据元素”(简称“元素”)。

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

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

举例
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值