c语言采用的数据存储结构及所代表的含义,数据结构第一章---绪论(2)

1.2基本概念和术语

1.2.1前言

1.2.2基本概念和术语

1.2.1前言

参照课本,在本节中,将介绍一些概念和术语并确定其含义,请注意区分和理解这些含义和所应用的层次(数学层面、计算机层面等),以方便实际应用。

tips:数学层次是通用层次,在计算机层面是普适的。

1.2.2基本概念和术语

数学层次

(1)数据(data):

对客观事物的符号表示,

在计算机科学中,指所有能被输入到计算机中,并能被程序处理的符号的总称。

(2)数据元素(data element):

数据元素是数据的基本单位,在计算机程序中常作为一个整体处理。

类似于节点(node),也可以理解成向量组中的一个向量。

(3)数据项(data item):

有时,单个数据元素可以由若干个数据项组成,例如书目信息的一项包含书名、作者名、书号等等信息。

数据项是数据的不可分割的最小单位。

数据项可以理解为数据元素(类似于向量)在不同维度的分量,而其值就是分量的值。

(4)数据对象(data object):

数据对象是性质相同的数据元素的集合。

数据对象可以理解为一个向量组,包含着许多相干的向量(数据元素)。

(5)数据结构(data structure):

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

数据结构根据结构中元素之间的关系的特性不同,通常有下列4类基本结构:

(1)集合:由离散的节点构成的集合体,数据元素除了同属于一个集合外,无其它的关系。

(2)线性:节点间存在线性连接,数据元素之间存在前驱或者后继的一对一的关系。

(3)树形结构:节点呈现树状,数据元素间存在类似于父节点与子节点的一对多的关系。

(4)图状结构或网状结构:节点呈现网状,数据元素间存在多对多的辐射状关系。

254d523ac27e

image.png

数据结构的形式定义为:数据结构是一个二元组

Data_Structure = ( D , S )

其中:D是数据元素的有限集,S是D上的关系的有限集。

下面是一个例子:

在计算机科学中,复数可取如下定义:复数是一种数据结构

Complex = ( C , R )

其中,C是两个实数的集合{c1,c2};R={P},而P是定义在集合C上的一种关系{},其中,序偶表示c1是实数的实部,c2是实数的虚部。

(5)逻辑结构:

结构定义中的“关系”描述的是数据元素之间的逻辑关系,因此又称为逻辑结构。

数据的逻辑结构是对数据之间关系的描述,有时就把逻辑结构简称为数据结构。

根据数据元素间逻辑关系的不同,可以将数据结构按逻辑分为两类:

线性数据结构:线性表、栈、队列、数组、字符串

非线性数据结构:树、二叉树、图

计算机层次

(1)存储结构:

数据结构在计算机中的表示(又称映像)称为数据的物理结构,又称存储结构。

在计算机中,可以用一个由若干位(bit)组合形成的一个位串表示一个数据元素,这个位串称为元素(element)或是节点(node)。当数据结构由若干数据项组成时,位串中对应各个数据项的子位串称为数据域(data filed)。因此,元素或节点可以看成数据元素在计算机中的映像。

数据元素之间的关系在计算机中有两种不同的表示方法:顺序映像和非顺序映像,并得到两种不同的存储结构:顺式存储结构和链式存储结构。

(1.1)顺式存储结构:

顺式存储结构借助元素在存储器中的相对位置来表示数据元素间的逻辑关系。

其特点是:数据元素的地址是连续的。

(1.2)链式存储结构:

链式存储结构借助指针(pointer)来表示元素间的逻辑关系。

其特点是:数据元素间的地址不一定连续,每一个节点的数据域占用一片连续的存储空间。(如链表)

254d523ac27e

image.png

数据类型(data type)

(1)数据类型是一个值的集合和定义在这个值上的一组操作的总称。

区别于高级程序语言中的定义,这里不仅仅是值的类型,也包含值上的操作。

(2)抽象数据类型(abstract data type,简称ADT)

抽象数据类型是指一个数学模型以及定义在该模型上的一组操作。

注:抽象数据类型的定义仅取决于它的一组逻辑特性,而与其在计算机内部的如何表示和实现无关,即不论其内部结构如何变化,只要它的数学特性不变,都不影响其外部使用。

高级程序设计语言中数据类型可分为两类,一类是非结构的原子类型,另一类是结构类型,其中原子类型的值是不可分解的,而结构类型的值是由若干成分按某种结构组成的,因此是可分解的。

而抽象数据类型按其值的特性可以分为以下三类:

(2.1)原子类型(atomic data type):

属于原子类型的变量的值是不可分解的,一般来说已有的原子类型已经足够,但有时也有必要定义新的原子数据类型,如上百位的整数或是新类型的指针。

(2.2)固定聚合类型(fixed-aggregate data type):

属于该类型的变量,其值由确定数目的成分按某种结构组成。例如,复数是由两个实数按次序分别作为实部和虚部的系数而构成。

(2.3)可变聚合类型(variable-aggregate data type):

和固定聚合类型相比,其组成结构的成分的数目不固定。例如,定义一个有序整数列的抽象类型,序列的长度是可变的。

显而易见,后两种抽象数据类型属于结构类型。

抽象数据类型和数据类型实质上是一个概念,例如整数或是数组也可看做抽象数据类型。

下面给出抽象数据类型的形式定义:

ADT = ( D , S , P )

其中,D是数据对象,S是D上的关系集,P是对D的基本操作集。

现采取以下格式定义抽象数据类型

ADT 抽象数据类型名{

数据对象:

数据关系:

数据操作:

}ADT 抽象数据类型名

其中,数据对象和数据关系的定义用伪代码表示,基本操作的定义格式为

基本操作名(参数表)

初始条件:

操作结果:

基本操作有两种参数,赋值参数只为操作提供输入值,引入参数以&前缀,除可提供输入值外,还将返回操作结果。若初始条件为空,则省略初始条件。

下面是一个例子:

ADT Triplet{

数据对象:D = {e1,e2,e3|e1,e2,e3∈Elemset (定义了关系运算的某个集合)}

数据关系:R = {,}

基本操作:

InitTriplet( &T , v1 , v2 , v3 )

操作结果:构建了三元组T,元素e1,e2,e3分别被赋以参数 v1, v2, v3的值。

DestroyTriplet( &T )

操作结果:三元组T被销毁。

Get( T , i , &e )

初始条件:三元组T已存在,1<= i <= 3。

操作结果:用 e 返回 T 的第 i 元的值。

Put( &T , i , e )

初始条件:三元组T已存在,1<= i <= 3。

操作结果:改变T的第 i 元的值为 e。

IsAscending( T )

初始条件:三元组T已存在。

操作结果:如果T的3个元素按升序排列,则返回1,否则返回0。

IsDescending( T )

初始条件:三元组T已存在。

操作结果:如果T的3个元素按降序排列,则返回1,否则返回0。

Max( T , &e )

初始条件:三元组T已存在。

操作结果:用e返回T中三个元素的最大值。

Min( T , &e )

初始条件:三元组T已存在。

操作结果:用e返回T中三个元素的最小值。

}ADT Triplet

(3)多形数据类型(polymorphic data type)是指其值的成分不确定的数据类型。例如例子中的e1,e2,e3,可以是整数、字符、字符串,甚至是更复杂的结构类型,只需要能进行关系运算即可。然而,不论其元素具有何种特性,元素之间的关系相同,基本操作也相同。

图源:《数据结构(C语言版)》严蔚敏、吴伟民 编著 清华大学出版社出版

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
数据结构》(C语言版)是为“数据结构”课程编写的教材,也可作为学习数据结构及其算法的C程序设计的参数教材。学了数据结构后,许多以前写起来很繁杂的代码现在写起来很清晰明了. 本书的前半部分从抽象数据类型的角度讨论各种基本类型的数据结构及其应用;后半部分主要讨论查找和排序的各种实现方法及其综合分析比较。 全书采用C语言作为数据结构和算法的描述语言。 本书概念表述严谨,逻辑推理严密,语言精炼,用词达意,并有配套出版的《数据结构题集》(C语言版),便于教学,又便于自学。 本书后附有光盘。光盘内容可在DOS环境下运行的以类C语言描述的“数据结构算法动态模拟辅助教学软件,以及在Windows环境下运行的以类PASCAL或类C两种语言描述的“数据结构算法动态模拟辅助教学软件”。内附 数据结构算法实现(严蔚敏版配套实现程序) 目录: 第1章 绪论 1.1 什么是数据结构 1.2 基本概念和术语 1.3 抽象数据类型的表现与实现 1.4 算法和算法分析 第2章 线性表 2.1 线性表的类型定义 2.2 线性表的顺序表示和实现 2.3 线性表的链式表示和实现 2.4 一元多项式的表示及相加 第3章 栈和队列 3.1 栈 3.2 栈的应有和举例 3.3 栈与递归的实现 3.4 队列 3.5 离散事件模拟 第4章 串 4.1 串类型的定义 4.2 串的表示和实现 4.3 串的模式匹配算法 4.4 串操作应用举例 第5章 数组和广义表 5.1 数组的定义 5.2 数组的顺序表现和实现 5.3 矩阵的压缩存储 5.4 广义表的定义 5.5 广义表的储存结构 5.6 m元多项式的表示 5.7 广义表的递归算法第6章 树和二叉树 6.1 树的定义和基本术语 6.2 二叉树 6.2.1 二叉树的定义 6.2.2 二叉树的性质 6.2.3 二叉树的存储结构 6.3 遍历二叉树和线索二叉树 6.3.1 遍历二叉树 6.3.2 线索二叉树 6.4 树和森林 6.4.1 树的存储结构 6.4.2 森林与二叉树的转换 6.4.3 树和森林的遍历 6.5 树与等价问题 6.6 赫夫曼树及其应用 6.6.1 最优二叉树(赫夫曼树) 6.6.2 赫夫曼编码 6.7 回溯法与树的遍历 6.8 树的计数 第7章 图 7.1 图的定义和术语 7.2 图的存储结构 7.2.1 数组表示法 7.2.2 邻接表 7.2.3 十字链表 7.2.4 邻接多重表 7.3 图的遍历 7.3.1 深度优先搜索 7.3.2 广度优先搜索 7.4 图的连通性问题 7.4.1 无向图的连通分量和生成树 7.4.2 有向图的强连通分量 7.4.3 最小生成树 7.4.4 关节点和重连通分量 7.5 有向无环图及其应用 7.5.1 拓扑排序 7.5.2 关键路径 7.6 最短路径 7.6.1 从某个源点到其余各顶点的最短路径 7.6.2 每一对顶点之间的最短路径 第8章 动态存储管理 8.1 概述 8.2 可利用空间表及分配方法 8.3 边界标识法 8.3.1 可利用空间表的结构 8.3.2 分配算法 8.3.3 回收算法 8.4 伙伴系统 8.4.1 可利用空间表的结构 8.4.2 分配算法 8.4.3 回收算法 8.5 无用单元收集 8.6 存储紧缩 第9章 查找 9.1 静态查找表 9.1.1 顺序表的查找 9.1.2 有序表的查找 9.1.3 静态树表的查找 9.1.4 索引顺序表的查找 9.2 动态查找表 9.2.1 二叉排序树和平衡二叉树 9.2.2 B树和B+树 9.2.3 键树 9.3 哈希表 9.3.1 什么是哈希表 9.3.2 哈希函数的构造方法 9.3.3 处理冲突的方法 9.3.4 哈希表的查找及其分析 第10章 内部排序 10.1 概述 10.2 插入排序 10.2.1 直接插入排序 10.2.2 其他插入排序 10.2.3 希尔排序 10.3 快速排序 10.4 选择排序 10.4.1 简单选择排序 10.4.2 树形选择排序 10.4.3 堆排序 10.5 归并排序 10.6 基数排序 10.6.1 多关键字的排序 10.6.2 链式基数排序 10.7 各种内部排序方法的比较讨论 第11章 外部排序 11.1 外存信息的存取 11.2 外部排序的方法 11.3 多路平衡归并的实现 11.4 置换一选择排序 11.5 最佳归并树 第12章 文件 12.1 有关文件的基本概念 12.2 顺序文件 12.3 索引文件 12.4 ISAM文件和VSAM文件 12.4.1 ISAM文件 12.4.2 VSAM文件 12.5 直接存取文件(散列文件) 12.6 多关键字文件 12.6.1 多重表文件 12.6.2 倒排文件 附录A 名词索引 附录B 函数索引 参考书目
作 者:严蔚敏 李冬梅 吴伟民 出版时间:2011-2-1 0:00:00 [1] 字 数:398千字 责任编辑:蒋亮 页 数:236页 开 本:16 ISBN书号:978-7-115-23490-2 所属分类:本科 >> 计算机类 >> 数据结构与算法 所属丛书:21世纪高等学校计算机规划教材——名家系列 定 价:¥28.00元 第1章 绪论 1 1.1 数据结构的研究内容 1 1.2 基本概念和术语 3 1.2.1 数据数据元素、数据项和数据对象 3 1.2.2 数据结构 4 1.2.3 数据类型和抽象数据类型 6 1.3 抽象数据类型的表示与实现 7 1.4 算法和算法分析 11 1.4.1 算法的定义及特性 11 1.4.2 评价算法优劣的基本标准 11 1.4.3 算法的时间复杂度 12 1.4.4 算法的空间复杂度 14 1.5 小结 15 习题 16 第2章 线性表 18 2.1 线性表的类型定义 18 2.1.1 线性表的定义和特点 18 2.1.2 线性表的抽象数据类型定义 18 2.2 线性表的顺序表示和实现 19 2.2.1 线性表的顺序存储表示 19 2.2.2 顺序表中基本操作的实现 20 2.3 线性表的链式表示和实现 24 2.3.1 单链表的定义和表示 24 2.3.2 单链表基本操作的实现 26 2.3.3 循环链表 31 2.3.4 双向链表 32 2.4 线性表的应用 34 2.4.1 一般线性表的合并 34 2.4.2 有序表的合并 35 2.4.3 一元多项式的表示及相加 37 2.5 小结 40 习题 41 第3章 栈和队列 44 3.1 栈 44 3.1.1 栈的类型定义 44 3.1.2 顺序栈的表示和实现 45 3.1.3 链栈的表示和实现 47 3.2 栈的应用 48 3.2.1 数制转换 49 3.2.2 括号匹配的检验 49 3.2.3 表达式求值 51 3.3 栈与递归 54 3.3.1 采用递归算法解决的问题 54 3.3.2 递归过程与递归工作栈 57 3.3.3 递归算法的效率分析 59 3.3.4 将递归转换为非递归的方法 60 3.4 队列 61 3.4.1 队列的类型定义 61 3.4.2 循环队列——队列的顺序表示和实现 62 3.4.3 链队——队列的链式表示和实现 65 3.5 队列的应用 67 3.6 小结 69 习题 69 第4章 串、数组和广义表 73 4.1 串 73 4.1.1 串的类型定义 73 4.1.2 串的存储结构 75 4.1.3 串的模式匹配算法 76 4.2 数组 83 4.2.1 数组的类型定义 83 4.2.2 数组的顺序存储 84 4.2.3 特殊矩阵的压缩存储 85 4.3 广义表 87 4.3.1 广义表的定义 87 4.3.2 广义表的存储结构 88 4.4 小结 90 习题 91 第5章 树和二叉树 94 5.1 树的定义和基本术语 94 5.1.1 树的定义 94 5.1.2 树的基本术语 96 5.2 二叉树 97 5.2.1 二叉树的定义 97 5.2.2 二叉树的性质 100 5.2.3 二叉树的存储结构 102 5.3 遍历二叉树和线索二叉树 103 5.3.1 遍历二叉树 103 5.3.2 线索二叉树 109 5.4 树和森林 114 5.4.1 树的存储结构 114 5.4.2 森林与二叉树的转换 116 5.4.3 树和森林的遍历 116 5.5 赫夫曼树及其应用 117 5.5.1 赫夫曼树的基本概念 117 5.5.2 赫夫曼树的构造算法 118 5.5.3 赫夫曼编码 121 5.6 小结 123 习题 123 第6章 图 126 6.1 图的定义和基本术语 126 6.1.1 图的定义 126 6.1.2 图的基本术语 128 6.2 图的存储结构 129 6.2.1 邻接矩阵 130 6.2.2 邻接表 132 6.3 图的遍历 135 6.3.1 深度优先搜索 135 6.3.2 广度优先搜索 138 6.4 图的应用 139 6.4.1 最小生成树 139 6.4.2 最短路径 144 6.4.3 拓扑排序 150 6.4.4 关键路径 153 6.5 小结 158 习题 160 第7章 查找 164 7.1 查找的基本概念 164 7.2 线性表的查找 165 7.2.1 顺序查找 165 7.2.2 折半查找 166 7.3 树表的查找 169 7.3.1 二叉排序树 170 7.3.2 平衡二叉树 176 7.3.3 B-树 182 7.3.4 B+树 190 7.4 散列表的查找 192 7.4.1 散列表的基本概念 192 7.4.2 散列函数的构造方法 1
第1章 绪论 一、基本内容 数据数据元素、数据对象、数据结构存储结构数据类型等概念术语的确定含义;抽象数据类型的定义、表示和实现方法;描述算法的类C语言;算法设计的基本要求以及从时间和空间角度分析算法的方法。 二、学习要点 1.熟悉各名词、术语的含义,掌握基本概念,特别是数据的逻辑结构和存储结构之间的关系。分清哪些是逻辑结构的性质,哪些是存储结构的性质。 2.了解抽象数据类型的定义、表示和实现方法。 3.熟悉类C语言的书写规范,特别要注意值调用和引用调用的区别,输入、输出的方式以及错误处理方式。 4.理解算法五个要素的确切含义:①动态有穷性(能执行结束);②确定性(对于相同的输入执行相同的路径);③有输入;④有输出;⑤可行性(用以描述算法的操作都是足够基本的)。 5.掌握计算语句频度和估算算法时间复杂度的方法。 三、基础知识题 1.1 简述下列术语:数据数据元素、数据对象、数据结构存储结构数据类型和抽象数据类型。 答:数据是对客观事物的符号表示,在计算机科学中是指所有能输入到计算机中并被计算机程序处理的符号的总称。 数据元素是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。 数据对象是性质相同的数据元素的集合,是数据的一个子集。 数据结构是相互之间存在一种或多种特定关系的数据元素的集合。 存储结构数据结构在计算机中的表示(又称映像)。 数据类型是一个值的集合和定义在这个值集上的一组操作的总称。 抽象数据类型是指一个数学模型以及定义在该模型上的一组操作。 1.2 试描述数据结构和抽象数据类型的概念与程序设计语言中数据类型概念的区别。 答:简单地说,数据结构定义了一组按某些关系结合在一起的数组元素。数据类型不仅定义了一组带结构的数据元素,而且还在其上定义了一组操作。程序设计语言中的数据类型是一个值的集合和定义在这个值集上的一组操作的总称。而抽象数据类型是指一个数学模型以及定义在该模型上的一组操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值