数据结构概述

什么是数据结构?

数据结构,直白地理解,就是研究数据的存储方式。
计算机要处理现实世界的信息,首先要做的就是把现实世界的的信存储到计算机中,只有把现实世界的信息存储到计算中计算机才有办法处理这些数据,现实世界的信息不但有信息本身包含的数据而且数据之间还有关系。
在这里插入图片描述

常用的数据结构

由上可知,数据结构主要是研究现实世界的信息在计算机中的存储方式。常见的有以下几种

  • 线性表,还可细分为顺序表、链表、栈和队列;
  • 树结构,包括普通树,二叉树,线索二叉树等;
  • 图存储结构

线性表

线性表结构存储的数据往往是可以依次排列的,就像小朋友手拉手,每位学生的前面和后面都仅有一个小朋友和他拉手,具备这种“一对一”关系的数据就可以使用线性表来存储。
在这里插入图片描述

例如,存储类似 {1,3,5,7,9} 这样的数据时,各元素依次排列,每个元素的前面和后边有且仅有一个元素与之相邻(除首元素和尾元素),因此可以使用线性表存储。

线性表并不是一种具体的存储结构,它包含顺序存储结构链式存储结构,是顺序表和链表的统称。
顺序表:理解为数组即可
在这里插入图片描述
链表:与顺序表不同顺序表的元素是顺序存放的,链表的元素在计算机中是离散存放的;
为了给各个数据块建立“依次排列”的关系,链表给各数据块增设一个指针,每个数据块的指针都指向下一个数据块(最后一个数据块的指针指向 NULL),就如同一个个小学生都伸手去拉住下一个小学生的手,这样,看似毫无关系的数据块就建立了“依次排列”的关系,也就形成了链表
在这里插入图片描述

栈和队列

栈和队列隶属于线性表,是特殊的线性表,因为它们对线性表中元素的进出做了明确的要求

栈中的元素只能从线性表的一端进出,且要遵循“先进后出”的原则,即先进栈的元素后出栈。
在这里插入图片描述
栈的结构可以用一个铁路调度图来形象的说明:火车只能从一面进入从另一面出,同时先进入的火车最后才可以出来

队列中的元素只能从线性表的一端进,从另一端出,且要遵循“先入先出”的特点,即先进队列的元素也要先出队列。

队列结构示意图
队列结构如图所示,队列中有 n 个元素,分别是 a1、a2 、a3和 an,从在队列中的状态可以看出是 a1 先进队列,然后 a2 、a3 进,最后 an 进。根据“先进先出”的原则,n 个元素出队列的顺序应该是 a1 最先出队列,然后 a2、a3出,最后 an 出。

树存储结构

树存储结构适合存储具有“一对多”关系的数据。
在这里插入图片描述

图存储结构

图存储结构适合存储具有“多对多”关系的数据。
在这里插入图片描述

逻辑结构与物理结构

逻辑结构

数据的逻辑结构,简单地理解,就是指的数据之间的逻辑关系。
数据之间的逻辑关系可细分为三类,“一对一”、“一对多”和“多对多”
通过学习数据结构,我们可以学到 3 种存储结构分别存储这 3 类逻辑关系的数据,换句话说:

  • 线性表用于存储具有“一对一”逻辑关系的数据;
  • 树结构用于存储具有“一对多”关系的数据;
  • 图结构用于存储具有“多对多”关系的数据;

由此,我们可以通过分析数据之间的逻辑关系来决定使用哪种存储结构,但具体使用顺序存储还是链式存储,还要通过数据的物理结构来决定

物理结构

数据的存储结构,也就是物理结构,指的是数据在物理存储空间上选择集中存放还是分散存放

数据物理结构视实际的情况而定,并且,数据的用途不同,选择的存储结构也不同。将数据进行集中存储有利于后期对数据进行遍历操作,而分散存储更有利于后期增加或删除数据。

因此,如果后期需要对数据进行大量的检索(遍历),就选择集中存储;反之,若后期需要对数据做进一步更新(增加或删除),则选择分散存储。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jie3606

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值