数据结构基本概念

1.数据

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

2.数据元素

数据元素是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。一个数据元素可由若干个数据项组成。

3.数据项

数据项是数据结构中讨论的最小单位,是数据记录中最基本、不可分的数据单位。

4.数据对象

数据对象是性质相同的数据元素的集合,是数据的一个子集。例如,大写字母就是一个数据对象,大写字母的数据对象是集合{‘A’,B’,…,‘Z’}。

5.数据结构定义

数据结构是指相互之间存在一种或多种特定关系的数据元素的集合。数据结构包括三个方面的内容:逻辑结构存储结构数据的运算

6.数据的逻辑结构

数据的逻辑结构是对数据元素之间的逻辑关系的描述,它与数据的存储结构无关,同一种逻辑结构可以有多种存储结构。归纳起来,数据的逻辑结构分为线性结构非线性结构

7.数据的物理结构

数据的物理结构又称为存储结构,是数据逻辑结构在计算机中的表示(又称映像)。它包括数据元素的表示和关系的表示。数据的存储结构是逻辑结构用计算机语言的实现,它依赖于计算机语言。数据的存储结构主要有:顺序存储链式存储索引存储散列存储
(1)顺序存储:把逻辑上相邻的元素存储在物理位置上也相邻的存储单元,元素之间的关系由存储单元的邻接关系来体现。其优点是可以实现随机存取,每个元素占用最少的空间;缺点是只能使用相邻的一整块存储单元,因此可能产生较多的外部碎片。
(2)链式存储:不要求逻辑上相邻的元素在物理位置上也相邻,借助指示元素存储地址的指针表示元素之间的逻辑关系。其优点是不会出现碎片现象,充分利用所有存储单元;缺点是每个元素因存储指针而占用额外的存储空间,并且只能实现顺序存取。
(3)索引存储:在存储元素的信息的同时,还建立附加的索引表。索引表中的每一项称为索引项,索引项的一般格式是:(关键字,地址)。其优点是检索速度快;缺点是增加了附加的索引表,会占用较多的存储空间。另外,在增加和删除数据时要修改索引表,因而会花费较多的时间。
(4)散列存储:根据元素的关键字直接计算出该元素的存储地址,又称为Hash存储。其优点是检索、增加和删除结点的操作都很快;缺点是如果散列函数不好可能出现元素存储单元的冲突,而解决冲突会增加时间和空间的开销。

8.数据的运算

施加在数据上的运算包括运算的定义和实现。运算的定义是指针对逻辑结构的,指出运算的功能;运算的实现是针对存储结构的,指出运算的具体操作步骤。

9.数据类型

数据类型是一个值的集合和定义在此集合上的一组操作的总称。
(1)原子类型:其值不可再分的数据类型。
(2)结构类型:其值可以再分解为若干成分(分量)的数据类型。
(3)抽象数据类型:抽象数据组织和与之相关的操作。

10.抽象数据类型

抽象数据类型(ADT)是指一个数学模型以及定义在该模型上的一组操作。抽象数据类型的定义仅取决于它的一组逻辑特性,而与其在计算机内部如何表示和实现无关,即无论其内部结构如何变化,只要他的数学特性不变,都不影响其外部使用。通常用(数据对象、数据关系、基本操作集)这样的三元组来表示抽象数据类型。


例题:
1.对于两种不同的数据结构,逻辑结构或物理结构一定不相同吗?
答:对于两种不同的数据结构,他们的逻辑结构和物理结构完全有可能相同。比如二叉树和二叉排序树,二叉排序树可以采用二叉树的逻辑表示和存储方式,前者通常用来表示层次关系,而后者通常用于排序和查找。虽然它们的运算都有建立树、插入结点、删除结点和查找结点等,但是,对于二叉树和二叉排序树,这些运算的定义是不同的,以查找结点为例,二叉树的时间复杂度为O(n),而二叉排序树的时间复杂度为O(log2n)。
2.试举例说明对相同的逻辑结构,同一种运算在不同存储方式下实现,其运算效率不同。
答:线性表既可以用顺序存储方式实现,也可以用链式存储方式实现。在顺序存储方式下,在线性表中插入和删除元素,平均要移动近一半的元素,时间复杂度为O(n);而在链式存储结构下,插入和删除的时间复杂度都是O(1)。


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值