二叉树结构体定义_数据结构基本概念

本文介绍了数据结构的基本概念,包括数据、数据元素、数据对象、数据结构、数据类型和抽象数据类型ADT。重点阐述了数据结构的三要素——逻辑结构、存储结构和数据的运算,以二叉树为例,讨论了不同的存储结构如顺序存储和链式存储的优缺点,并解释了数据运算如何根据存储结构的不同而有所差异。
摘要由CSDN通过智能技术生成

数据结构的基本概念

f7cf733a98e09d21a63cd8778c71d970.png

数据

数据是信息的载体,是描述客观事物属性的数、字符及所有能输入到计算机中并被计算机程序识别和处理的符号集合。数据是计算机程序加工的原料。

数据元素、数据项

数据元素是数据的基本单位,通常作为一个整体进行考虑和处理。一个数据元素可由若干数据项组成,数据项是构成数据元素的不可分的最小单位。

一个账号是数据元素,每个账号的信息是数据项,如果有一个信息很多就可以再把它拆分为多个数据项,相应的该信息叫做组合项。

数据对象、数据结构

数据对象是具有相同性质的数据元素的集合,是数据的一个子集。

数据结构是相互之间存在一种或多种特定关系的数据元素的集合。

数据结构关心强调数据之间要有关系,数据对象关心强调的是数据具有相同的性质。

数据类型、抽象数据类型

数据类型是一个值的集合和定义在此集合的一组操作的总称。

具体数据类型

1)原子类型(基本数据类型)。其值不可再分的数据类型。

如:bool类型。值的范围:true、false。可进行的操作:与、或、非等逻辑运算

2)结构类型(struct结构体)。其值可以再分解为若干成分的数据类型

抽象数据类型ADT

抽象数据组织及与之相关的操作。

ADT用数学化的语言定义数据的逻辑结构和运算,与具体的实现无关。通常用(数据对象,数据关系,基本操作集)这样的三元组来表示,可以定义一个完整的数据结构

数据结构三要素

逻辑结构

1b69ccf7a8493f254c3b2469b4feb13c.png

栈、队列、集合、线性表、一般树、二叉树、有向图、无向图都是ADT

数据的逻辑结构和存储结构是密不可分的,一个算法的设计取决于所选定的逻辑结构,而算法的实现依赖于采用的存储结果。

数据的逻辑结构是从面相实际问题的角度出发的,只采用抽象表达方式,独立于存储结构,数据的存储方式有多种不同的选择。而数据的存储结构是逻辑结构在计算机上的映射,它不能独立于逻辑结构而存在。

对于两种不同的数据结构,它们的逻辑结构和物理结构完全有可能相同。因为数据结构还有数据的运算这一要素。

比如,二叉树和二叉排序树,二叉排序树可以采用二叉树的逻辑表示和存储方式,前者通常用于表示层次关系,而后者通常用于排序和查找。虽然它们的运算都有建立树、插入结点、删除结点和查找结点等功能,但对于二叉树和二叉排序树,这些运算的定义是不同的,以查找结点为例,二叉树的时间复杂度是O(n),而二叉排序树的时间复杂度是O(log2n)。

存储结构

f1be61e27cec06b0e2ae6459fe530900.png

  • 顺序存储:把逻辑上相邻的元素存储在物理位置上也相邻(物理地址相邻)的存储单元中。

    • 优点:是可以实现随机存取,每个元素占用最少的存储空间。

    • 缺点:是只能使用相邻的一整块存储单元,因此可能产生较多的外部碎片。

  • 链式存储:不要求逻辑上相邻的元素在物理存储上也相邻,借助指示元素存储地址的指针来表示元素之间的逻辑关系。

    • 缺点:每个元素因存储指针而占用额外的存储空间,且只能实现顺序存取。

    • 注意:链式存储设计中,不同结点的存储空间可以不连续,但结点内的存储单元地址必须连续。

    • 优点:不会出现碎片现象,能充分利用所有存储单元。

  • 索引存储:在存储元素信息的同时,还建立附加的索引表。

    • 缺点:附加的索引表额外占用存储空间。

    • 优点:检索速度快。

  • 散列存储:根据元素的关键字直接计算出该元素的存储地址,又称哈希(Hash)存储。

    • 优点:检索、增加和删除结点的操作都很快。

    • 缺点:若散列函数不好,则可能出现元素存储单元的冲突,而解决冲突会增加时间和空间开销。

数据的存储结构会影响存储空间分配的方便程度

数据的存储结构会影响对数据运算的速度和效率

如:线性表既可以用顺序存储方式,也可以用链式存储方式实现。在顺序存储方式下,插入和删除操作时间复杂度为O(n),而在链式存储方式下,插入和删除操作时间复杂度都是O(1)。

数据的运算

运算的定义是针对逻辑结构。指出运算的功能,运算的实现是针对存储结构的,指出运算的具体操作步骤。

数据结构的定义

在探讨定义一个数据结构时:

①先定义逻辑结构(即数据元素之间的关系)

如:线性表的定义

②再定义数据的运算(针对现实需求,应该对这种逻辑结构做什么样的运算)s

③最后确定某种存储结构,实现数据结构,并实现一些对数据结构的基本运算。

栈、队列、集合、线性表、一般树、二叉树、有向图、无向图都是ADT

循环队列、顺序表、链表、等都是数据结构=ADT+存储结构

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值