数据结构基础知识

什么是数据结构?

简单理解,就是数据的存储方式

数据存储方式的选择取决于两方面,即数据的逻辑结构和存储结构(物理结构)

逻辑结构:

简单理解,就是数据之间的逻辑关系

  • 线性结构(线性表):线性结构是一种有序数据项的集合,其存储的数据往往是可以依次排列的,具备“一对一”的逻辑关系,其中每个数据项都有唯一的前驱和后继。
    包括
    1、顺序表:简单理解就是常用的数组,需要提前申请一定大小的存储空间,这块存储空间的物理地址是连续的
    2、链表:使用链表存储数据时,是随用随申请,因此数据的存储位置是相互分离的,不会占用一整块的存储空间,数据的存储位置是随机的
    3、:栈中的元素只能从线性表的一端进出(另一端封死),遵循“先进后出”的原则
    4、队列:队列中的元素只能从线性表的一端进,从另一端出,遵循“先进先出”的特点
  • 非线性结构:其中存储的数据具备“一对多”或者“多对多”的逻辑关系,其逻辑特征是一个数据项可能有多个直接前驱和多个直接后继
    包括
    1、:存储具有“一对多”关系的数据
    2、:存储具有“多对多”关系的数据
存储结构(物理结构)

简单理解,就是数据的逻辑结构在计算机内存中的存储方式
具体两种,指数据在计算机内存中是集中存储还是分散存放

  • 顺序存储结构:采用一组连续的存储单元(内存)存放所有的数据元素,逻辑上相邻的元素,其存储单元(内存)也是相邻的;
    也可以直接说:顺序存储结构将数据的逻辑结构直接映射到存储结构上了
  • 链式存储结构:每个结点单独存储,不占用一整块存储空间,为了表示结点之间的关系,给每个结点附加指针,用于存放相邻结点在存储中的存储地址
注:

1、我们可以使用顺序存储结构实现栈、队列,也可以使用链式存储结构实现栈和队列
2、一维数组是线性结构
3、二维及多维数组是非线性结构,因为其是由多个一维数组组成,
比如:二维数组的a[0],对应着a[0][0]和a[0][1],这是一对多的逻辑关系,所以是非线性结构

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值