数据结构第1章
精品课件-数据结构教程(胡元义)-第1章

第1章 绪论
顺序存储结构的主要优点是节省存储空间,即分配给数据 的存储单元全部用于存放数据元素的数据信息,数据元素之间 的逻辑关系没有占用额外的存储空间。采用这种存储结构可以 实现对数据元素的随机存取,即每个数据元素对应有一个序号, 并由该序号可以直接计算出数据元素的存储地址(例如对于数 组A其序号为数组元素的下标,数组元素A[i]可以通过*(A+i) 进行存取)。但顺序存储结构的主要缺点是不便于修改,对数 据元素进行插入、删除运算时,可能要移动一系列的数据元素。
第1章 绪论
(1) 分析阶段:分析实际问题,从中抽象出一个数学模 型。
(2) 设计阶段:设计出解决数学模型的算法。 (3) 编程阶段:用适当的编程语言编写出可执行的程序。 (4) 测试阶段:测试、修改直到得到问题的解答。 数据结构课程集中讨论软件开发过程中的设计阶段,同时 涉及分析阶段和编程阶段的若干基本问题。此外,为了构造出 好的数据结构及其实现,还需考虑数据结构及其实现的评价与 选择。因此,数据结构课程的内容包括了如表1.1所示的数据 表示和数据处理方面所对应的3个层次。
第1章 绪论
1.2.2 存储结构 数据的存储结构是数据结构在计算机中的表示方法,也即
数据的逻辑结构到计算机存储器的映像,包括数据结构中数据 元素的表示以及数据元素之间关系的表示。数据元素及数据元 素之间的关系在计算机中可以有以下四种基本存储结构:
(1) 顺序存储结构:借助于数据元素在存储器中的相对 位置来表示数据元素之间的逻辑关系。通常顺序存储结构是利 用程序语言中的数组来描述的。
第1章 绪论
《数据结构》(C语言版) 第一章 绪论 习题及答案

一、单选题1、______ 是数据的最小单位。
A、数据项B、表元素C、信息项D、数据元素2、以下说法不正确的是______。
A、数据可由若干个数据元素构成B、数据项可由若干个数据元素构成C、数据项是不可分割的最小标识单位D、数据元素是数据的基本单位3、数据结构是指 ______ 的集合以及它们之间的关系。
A、数据B、结构C、数据元素D、计算方法4、计算机所处理的数据一般具备某种内在联系,这是指 ______。
A、数据和数据之间存在某种关系B、元素和元素之间存在某种关系C、元素内部具有某种结构D、数据项和数据项之间存在某种关系5、在数据结构中,与所使用的计算机无关的是数据的 ______ 结构。
A、逻辑B、存储C、逻辑和存储D、物理6、数据的逻辑结构可以分为 ______ 两类。
A、紧凑结构和非紧凑结构B、动态结构和静态结构C、线性结构和非线性结构D、内部结构和外部结构7、数据的逻辑结构是指 ______ 关系的整体。
A、数据项之间逻辑B、数据元素之间逻辑C、数据类型之间D、存储结构之间8、以下是数据结构中 ______ 属非线性结构。
A、串B、栈C、队列D、平衡二叉树9、以下属于逻辑结构是 ______。
A、双链表B、单链表C、顺序表D、有序表10、以下不属于存储结构是______。
A、顺序表B、线性表C、邻接表D、单链表11、在计算机中存储数据时,通常不仅要存储各数据元素的值,而且还有存储 ______。
A、数据元素之间的关系B、数据元素的类型C、数据的处理方法D、数据的存储方法12、数据结构在计算机内存中的表示是指 ______。
A、数据的逻辑结构B、数据结构C、数据元素之间的关系D、数据的存储结构13、在数据的存储中,一个节点通常存储一个 ______。
A、数据结构B、数据元素C、数据项D、数据类型14、在决定选取任何类型的存储结构时,一般不多考虑 ______。
A、各节点的值如何B、节点个数的多少C、对数据有哪些运算D、所用编程语言实现这种结构是否方便15、数据在计算机的存储器中表示时,逻辑上相邻的两个元素对应的物理地址也是相邻的,这种存储结构称之为 ______。
《数据结构》吕云翔编著第1章绪论习题解答

《数据结构》吕云翔编著第1章绪论习题解答数据结构是计算机科学中的一个重要概念,它涉及到存储、组织和管理数据的方法和技术。
《数据结构》是吕云翔编著的一本经典教材,本文将就第1章绪论中的习题进行解答。
1. 为什么要学习数据结构?数据结构是计算机科学的基础,它为我们提供了存储和操作数据的方式。
学习数据结构能够帮助我们更好地理解和分析问题,设计高效的算法,并且能够为我们解决实际问题提供支持。
2. 什么是数据结构?数据结构指的是数据元素之间的关系,以及存储和访问这些数据的方法。
常见的数据结构包括数组、链表、栈、队列、树、图等。
每种数据结构都有各自的特点和适用场景。
3. 数据结构有哪些基本操作?数据结构的基本操作包括插入、删除和查找。
插入操作将一个新的元素插入到数据结构中,删除操作将一个元素从数据结构中移除,查找操作用于寻找特定元素的位置或者判断某个元素是否存在。
4. 什么是线性结构?线性结构是数据元素之间呈线性关系的数据结构。
常见的线性结构有数组和链表。
数组是一种连续存储数据元素的结构,链表是一种通过指针将数据元素链接起来的结构。
5. 什么是非线性结构?非线性结构是数据元素之间呈非线性关系的数据结构。
常见的非线性结构有树和图。
树是一种层次结构,图是由节点和边组成的结构,节点之间的关系可以是任意的。
6. 什么是抽象数据类型?抽象数据类型(ADT)是一种数学模型,它定义了一种数据类型的抽象行为和操作。
ADT将数据的逻辑结构和数据的物理存储分离,使得数据结构和数据操作可以独立地进行设计和实现。
7. 数据结构的选择原则是什么?选择适当的数据结构是解决问题的关键。
选择数据结构应该考虑到数据的特点、操作的效率和实际应用需求。
在选择数据结构时,需要综合考虑空间复杂度和时间复杂度的因素,并且合理权衡它们之间的关系。
8. 数据结构与算法之间有什么关系?数据结构和算法是紧密相关的。
数据结构提供了算法操作的底层基础,而算法则是对数据结构进行操作的具体步骤和方法。
数据结构第1章-答案

一、填空题01、数据结构是一门研究非数值计算的程序设计问题中计算机的(操作对象)以及它们之间的(关系和运算)等的学科。
02、数据结构被形式地定义为(D,R),其中D是(数据元素)的有限集合,R是D上的(关系)有限集合。
03、数据结构包括数据的(逻辑结构)、数据的(存储结构)和数据的(运算)这三个方面的内容。
04、数据结构按逻辑结构可分为两大类,它们分别是(线性结构)和(非线性结构)。
05、线性结构中元素之间存在(一对一)关系,树形结构中元素之间存在(一对多)关系,图形结构中元素之间存在(多对多)关系。
06、在线性结构中,第一个结点(没有)前驱结点,其余每个结点有且只有1个前驱结点;最后一个结点(没有)后续结点,其余每个结点有且只有1个后续结点。
07、在树形结构中,树根结点没有(前驱)结点,其余每个结点有且只有(1)个前驱结点;叶子结点没有(后续)结点,其余每个结点的后续结点数可以(任意多个)。
08、在图形结构中,每个结点的前驱结点数和后续结点数可以(任意多个)。
09、数据的存储结构可用四种基本的存储方法表示,它们分别是(顺序)、(链式)、(索引)、(散列)。
10、对于给定的n个元素,可以构造出的逻辑结构有(集合)、(线性结构)、(树形结构)、(图状结构)四种。
11、数据的运算最常用的有5种,它们分别是(插入)、(删除)、(修改)、(查找)、(排序)。
12、一个算法的效率可分为(时间)效率和(空间)效率。
13、数据结构中评价算法的两个重要指标是算法的(时间复杂度)和(空间复杂度)。
14、一个数据结构在计算机中的(映射)称为存储结构。
15、算法的五个重要特性是(有穷性)、(确定性)、(可行性)、输入、输出。
16、已知如下程序段for (i=n; i>=1; i--) //语句1{ x++; //语句2for (j=n; j>=i; j--) //语句3y++; //语句4}语句 1 执行的频度为(n+1);语句2执行的频度为(n);语句3执行的频度为(n(n+3)/2);语句4执行的频度为(n(n+1)/2)。
数据结构第1章 绪论

课程改革: 课程改革:
实验单独设课, 强调上机实践能力 数据结构课程: 理论课(68课时4学分)+实验课(24课时1.5 学分) 课程考核
1.3 基本概念和术语
1、 2、 3、 4、 5、 6、 数据 数据元素 数据对象 数据结构 数据类型 抽象数据类型
1. 数据 能输入到计算机中的符号集 数据: 合. 2. 数据元素 数据的基本单位. 数据元素: 3. 数据对象 数据对象: 具有相同性质的数据元素的集合. 4. 数据结构: DATA STRUCTURE 数据结构: 数据及其相互关 系的集合. 分为逻辑结构和存储结构(物理结 构). 数据结构-------------------------------类 数据结构----------------类 CLASS
数据的存储结构
1. 顺序存储结构 顺序存储结构:借助元素在存储器中的相对位置 来表示数据元素间的逻辑关系。 【例1.4】对于表1-1提出的学生信息登记表进行存储, 假定每个元素占用50个存储单元,数据从1000号单 元开始由低地址向高地址存放,对应的顺序存储结 构如表1-3所示。
数据的存储结构
顺序存储结构的主要特点: 可实现对各数据元素的随机访问。这是 因为只要知道存储的首地址以及每个数 据元素所占的存储单元,就可以计算出 各数据元素的存储地址。 不利于修改,在对数据元素进行插入、 删除运算时可能要移动一系列的数据元 素。
抽象数据类型的定义: 抽象数据类型的定义:
ADT: ADT:抽象数据类型名 data 数据元素之间逻辑关系定义 operation 操作1 操作1 操作2 操作2
……
操作n 操作n
抽象数据类型 的不同视图
1.4 1.4 算法和算法分析
1. 定义:算法(Algorithm)是对特定问题求 定义:算法(Algorithm) 解步骤的一种描述,它是指令的有限序列, 解步骤的一种描述,它是指令的有限序列,其 中每一条指令表示一个或多个操作。 中每一条指令表示一个或多个操作 特性: 2. 特性:
数据结构第01章概论.ppt

(第2版)
李云清 杨庆红 揭安全
人民邮电出版社
1
第一章 概述
什么是数据结构 数据类型和抽象数据类型
算法和算法分析
退出
第一章 概述
瑞士著名的计算机科学家Nicklaus Wirth在1976 年出版了一本书,书名为《算法+数据结构 = 程序设 计》,它正说明了数据结构在程序设计中的作用。程序 设计的实质即为计算机处理问题编制一组"指令",首先 需要解决两个问题:即算法和数据结构。算法即处理问 题的策略,而数据结构即为问题的数学模型。
退出
1.1.4数据的运算集合
对于一批数据,数据的运算是定义在数据的逻 辑结构之上的,而运算的具体实现就依赖于数据的 存储结构。
数据的运算集合要视情况而定,一般而言,数据的 运算包括插入、删除、检索、输出、排序等。
插入:在一个结构中增加一个新的结点。
删除:在一个结构删除一个结点。
检索:在一个结构中查找满足条件的结点。
98
I 79
F
(a)城市距离图
A
34
12
B
H9
8
C
G
31
21
E 10
D
I 79
F
(b)联通各城市最小生成树
退出
以上所举例子中的数学模型正是数据结构要讨论 的问题。因此,简单地说,数据结构是一门讨论"描述 现实世界实体的数学模型(非数值计算)及其上的操作 在计算机中如何表示和实现"的学科。
退出
综上所述
对于一个数据结构B=(K,R),必须建立从结点 集合到计算机某个存储区域M的一个映象,这个映象 要直接或间接地表达结点之间的关系R。数据在计算 机中的存储方式称为数据的存储结构。
《数据结构》第一章重点知识梳理
第一章 绪论
求绝对值 abs(表达式) 求不足整数值 floor(表达式) 求进位整数值 ceil(表达式) 判定文件结束 eof(文件变量) (10)逻辑运算 与运算&&:对于A&&B,当A的值为0时,不在对B求值。 或运算||:对于A||B,当A的值为非0时,不在对B求值。 四、算法和算法分析 1.算法 (1)算法的定义
由于算法的时间复杂度考虑的只是对于问题规模n的增长率,因此在难以精确计算基本操作 执行次数(或语句频度)的情况下,只需求出它关于n的增长率或阶即可。 4.算法的存储空间需求
类似于算法的时间复杂度,以空间复杂度(spacecomplexity)作为算法所需存储空间的量 度,记作S(n)=O(f(n))其中n为问题的规模。
18
的表示。
①元素的表示。计算机数据元素用一个由若干位组合 起来形成的一个位串表示。
图1-1四类基本结构的关系图。
5
第一章 绪论
②关系的表示。 计算机中数据元素之间的关系有两种不同的表示方法:顺序映象和非顺序映象。 并由这两种不同的表示方法得到两种不同的存储结构:顺序存储结构和链式存储结构。 a.顺序映象的特点是借助元素在存储器中的相对位置来表示数据元素之间的逻辑关系。 b.非顺序映象的特点是借助指示元素存储地址的指针(pointer)表示数据元素之间的逻辑
数据元素(dataelement)是数据的基本单位,在计算机程序中通常作为一个整体进行考 虑和处理。
3
第一章 绪论
3.数据对象 数据对象(dataobject)是性质相同的数据元素的集合,是数据的一个子集。
4.数据结构 数据结构(datastructure)是相互之间存在一种或多种特定关系的数据元素的集合。 (1)数据结构的基本结构 根据数据元素之间关系的不同特性,通常有下列四类基本结构: ①集合。数据元素之间除了“同属于一个集合”的关系外,别无其它关系。 ②线性结构。数据元素之间存在一个对一个的关系。 ③树形结构。数据元素之间存在一个对多个的关系。 ④图状结构或网状结构。数据元素之间存在多个对多个的关系。
数据结构课后习题答案
大学课程《数据结构》课后习题答案第 1 章绪论课后习题讲解1. 填空⑴()是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。
【解答】数据元素⑵()是数据的最小单位,()是讨论数据结构时涉及的最小数据单位。
【解答】数据项,数据元素【分析】数据结构指的是数据元素以及数据元素之间的关系。
⑶从逻辑关系上讲,数据结构主要分为()、()、()和()。
【解答】集合,线性结构,树结构,图结构⑷数据的存储结构主要有()和()两种基本方法,不论哪种存储结构,都要存储两方面的内容:()和()。
【解答】顺序存储结构,链接存储结构,数据元素,数据元素之间的关系⑸算法具有五个特性,分别是()、()、()、()、()。
【解答】有零个或多个输入,有一个或多个输出,有穷性,确定性,可行性⑹算法的描述方法通常有()、()、()和()四种,其中,()被称为算法语言。
【解答】自然语言,程序设计语言,流程图,伪代码,伪代码⑺在一般情况下,一个算法的时间复杂度是()的函数。
【解答】问题规模⑻设待处理问题的规模为n,若一个算法的时间复杂度为一个常数,则表示成数量级的形式为(),若为n*log25n,则表示成数量级的形式为()。
【解答】Ο(1),Ο(nlog2n)【分析】用大O记号表示算法的时间复杂度,需要将低次幂去掉,将最高次幂的系数去掉。
2. 选择题⑴顺序存储结构中数据元素之间的逻辑关系是由()表示的,链接存储结构中的数据元素之间的逻辑关系是由()表示的。
A 线性结构B 非线性结构C 存储位置D 指针【解答】C,D【分析】顺序存储结构就是用一维数组存储数据结构中的数据元素,其逻辑关系由存储位置(即元素在数组中的下标)表示;链接存储结构中一个数据元素对应链表中的一个结点,元素之间的逻辑关系由结点中的指针表示。
⑵假设有如下遗产继承规则:丈夫和妻子可以相互继承遗产;子女可以继承父亲或母亲的遗产;子女间不能相互继承。
则表示该遗产继承关系的最合适的数据结构应该是()。
数据结构第一章
1.3 算法的描述
(2) 空间效率 一个算法在执行过程中所占用的存储空间大小,称为空间效率或空 间复杂度。与时间复杂度类似,空间复杂度是指算法在计算机内执行 时临时占用的存储空间大小。算法的空间复杂度一般以数量级形式给 出。 提高算法空间复杂度的措施有原地工作和压缩存储。
1.3 .4算法的描述语言
1.3 算法的描述
例1.6 求下列4个程序段的语句频度 (a) i++; x=0; (b)for(i=1;i<=n;i++) x=x+1;
(c)for(i=1;i<=n;i++) for (j=1;j<=n;j++) x=x+1;
(d)for(i=1;i<=n;i++) for (j=1;j<=n;j++) for (k=1;k<=n;k++) x=x+1;
记录号 学号 980001 980002 姓名 吴承志 李淑芳 性别 男 女 专 业 计算机科学与技术 信息与计算科学 年级 98级 2001级 98级 9,10 1,2 2000级 6,7,8
1 2 3 4 5
990301
990302
刘 丽
张会友
女
男
数学与应用数学
信息与计算科学
99级
99级
98级
99级
数学与应用数学
2000级 2001级
2001级
姓名索引表
9
10
学生信息表
教学计划编排问题 案例2
问题: 如何通过计算机编排教学计划? 算法分析: 一个教学计划包含许多课程,在教学计划包含的许多课程之间,有些必须按规 定的先后次序进行,有些则没有次序要求。即有些课程之间有先修和后续 的关系,有些课程可以任意安排次序。这种各个课程之间的次序关系可用 一个称作图的数据结构来表示
数据结构第一章--绪论(严蔚敏版)
解 T = (D, R ) D={A,B,a,b,c }
R是D上的关系的集合 是 上的关系的集合
A
B
a R={ P1,P2 } P1 ={<A,a>, <A,b>, <A,c>} P2 ={<B,a>, <B,b>, <B,c>}
b
c
写出一个复数的数据结构 例3 写出一个复数的数据结构 Complex= (C , R) 解 一个复数可以表示为 a+bi 一个复数可以表示为 复数 C={a,b}
也可以表示成一个有序对 <a, b>
∴这里存在一种关系 P ={<a,b>} (只有一个有序对 只有一个有序对) 只有一个有序对
而R是C上的关系的集合 R={ P } 是 上的关系的集合
写出一个复数的数据结构 例3 写出一个复数的数据结构 Complex= (C , R) 解 一个复数的数据结构为 Complex= (C , R) 其中, 其中, C={a,b} R={ P } P ={<a,b>}
a b c
解 其数据结构可描述为 d e T = (D, R ) D是数据元素的集合 D={a,b,c,d,e} 是数据元素的集合
R是D上的关系的集合 R={ P } 是 上的关系的集合
P ={<a,b>,<a,c>,<b,d>,<b,e>}
例2
一小组有a,b,c 三个学生,一个导师A 一小组有a,b,c 三个学生,一个导师A 和一个辅导员B 和一个辅导员B,此小组的数据结构如图:
48
ADT 抽象数据类型名 { 数据对象: 数据对象:〈数据对象的定义〉 数据关系: 数据关系:〈数据关系的定义〉 基本操作: 基本操作:〈基本操作的定义〉 } ADT 抽象数据类型名 其中基本操作的定义格式为: 基本操作名(参数表) 基本操作名 初始条件:〈初始条件描述〉 初始条件: 操作结果:〈操作结果描述〉 操作结果
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
课前指导
为什么学习数据结构 学习方法 考查要求 实验工具(C++/C语言) 教材与参考书
教材:《数据结构实用教程(C++版)》 参考书:《数据结构(C语言版)》
教学内容
第一章 第二章 第三章 第四章 第五章 第六章 第七章
算法的时间复杂度计算
设算法中所有语句的频度之和记作T(n),它是问题规 模n的某个函数f(n),记作:
T(n) = O(f(n))
语句在算法中被重复执 行的次数(Frequency Count)
它表示随问题规模n的增大,算法执行时间的增长率与 f(n) 的增长率相同。
基本操作的执行次数不确定时的时间复杂度 平均时间复杂度 依基本操作执行次数概率计算平均
例:线性表这样的抽象数据类型,其数学模型是:数据元素 的集合,该集合内的元素有这样的关系:除第一个和最后一 个外,每个元素有唯一的前趋和唯一的后继。可以有这样一 些操作:插入一个元素、删除一个元素等。 抽象数据类型分类 值不可分解,如int 值由确定数目的成分按某种结构组成,如 复数 值的成分数目不确定,如学生基本情况
数(整数,实数) 字符、字符串、文字、图形、图象、声音
数值数据
非数值数据
计算机解题步骤
数学模型 算法 编程、调试
具体问题
非数值计算问题
例1 书目自动检索系统
书目文件
线性表
樊映川
罗远祥
书目卡片 002 理论力学
001
高等数学
S01
L02
…
… …
索引表
登录号: 003 高等数学 华罗庚 S01 书名: 线性代数 004 栾汝书 S02 作者名: … … … … 分类号: 高等数学 001,003,… 樊映川 001,… L 出版单位: 理论力学 002,… 华罗庚 003,… S 出版时间: 线性代数 004,… 栾汝书 004,… … 价格:
例3 分析以下程序段的时间复杂度。
i=1;
while(i<n) i=i*2; (语句2)的频度为f(n),则有: (语句2) 的频度设为:f(n) (语句1) 的频度为:1
最坏情况下时间复杂度 在最坏情况下基本操作执行次数
例1 求下列算法段的语句频度
for(i=1; i<=n; i++) for(j =1; j <=i ; j++)
x=x+1;
分析:该算法为一个二重循环,执行次数为内、外循 环次数相乘,但内循环次数不固定,与外循环有关, n ( n 1) 因些,时间频度T(n)=1+2+3+…+n= 2
例2 分析以下程序段的时间复杂度 for (i=1;i<n;i++) { y=y+1; /* 1 * / for (j=0; j<=(2*n); j++) x++; /* 2 * / }
语句1的频度是:n-1
语句2的频度是:(n-1)(2n+1) 则该程序段的时间复杂度:T(n)=2(n2-1)=O(n2)
6201004 ... 整个表的记录是学生成绩数据对象
1.1.2 数据类型
定义:数据类型定义了一个数据的值域和对该数
据可进行的一组操作。
(1)基本数据类型——int char float double…
(2)构造型数据类型——数组、结构体、对象、
类…
1.1.3 抽象数据类型(ADT)
定义:抽象数据类型是与具体计算机内部表示与实 现方式无关的数据类型,由一个逻辑上的数学模 型和定义在该模型上的一组操作构成。 作用:抽象数据类型可以使我们更容易描述实际问 题。如用线性表描述学生成绩表,用树描述遗传 关系。 好处:可提高软件的复用程度。使用它的人可以只 关心它的逻辑特征,不需要了解它的存储方式。 定义它的人同样不必要关心它如何存储。
举例
例1-4 复数的数据结构
Complex=(C,R)
其中:C={c1,c2}; R={P}; P={<c1,c2>}
例1-5 课题小组的数据结构
Group=(P,R) 其中:P={T,G1,…,Gn,S11,…Snm,1≤n≤3,1≤m≤2} R={R1,R2} R1={<T,Gi>|1≤i≤n,1≤n≤3} R2={<Gi,Sij>|1≤i≤n,1≤j≤m,1≤n≤3,1≤m≤2}
存储结构:数据结构在计算机 中的表示。又称为物理结构。
系”指数据间的逻辑关系,故也称数据 结构为逻辑结构。
这三个方面的关系为:
(1)数据的逻辑结构独立于计算机,是数据 本身所固有的。
(2)存储结构是逻辑结构在计算机存储器中 的映像,必须依赖于计算机。 (3)运算是指所施加的一组操作总称。运算 的定义直接依赖于逻辑结构,但运算的实现必 须依赖于存储结构。
定义:是对客观事物的符号化表示,是信息、 例:张三的C语言考试成绩为92分,92就是该同学的成
绩数据。 概念与知识的载体。 –例:图像、声音、视频等。
数据项是数据不可分割的最小单位,反映客观 事物的某个属性。 学号 姓名 语文 数学 C语言 一个数据元素 数据元素是构成数据的具有相同性质的基本单 6201001 张三 85 54 92 元。在计算机程序中通常作为一个整体考虑和 6201002 李四 92 84 64 一个数据项 处理。 6201003 王五 87 74 73 数据对象是性质相同的数据元素的集合。
链式存储结构 借助存储元素地址的指针来表示数据元素之间 的逻辑关系;
存储地址 存储内容
Lo Lo+m 元素1
顺 序 存 储 结 构
元素2
……..
所有元素存放在一片连续 的存储单元中,逻辑上相 邻的元素存放到计算机内 存仍然相邻。
Lo+(i-1)*m
元素i ……..
Lo+(n-1)*m
元素n
m为每个元素所占 用的存储单元个数
原子类型 固定聚合类型 可变聚合类型
抽象数据类型表示法
(1)三元组表示:(D,S,P)
其中D是数据对象,S是D上的关系集,P是对D的基本操作集。
(2)本书采用的定义格式: ADT 抽象数据类型名{ 数据对象:<数据对象的定义> 数据关系:<数据关系的定义> 基本操作:<基本操作的定义> }
(3)基本操作的格式:
… …
按书名 按作者名
…
… 002,… 001,003,…
按分类号
例2 人机对奕问题
树
……..
……..
…...
…...
…...
…...
结论
《数据结构》是一门研究非数值计算的程序 设计问题中计算机的操作对象以及它们之间 的关系和操作的学科。
1.1 数据与数据类型
1.1.1 数据
学号 6201001 6201002 6201003 6201004 ... 姓名 张三 李四 王五 语文 85 92 87 数学 54 84 74 C语言 92 64 73
算法设计举例
max(int a,int b,int c) {if (a>b) {if(a>c) return a; else return c; 在3个整数 } 中求最大 else {if(b>c) return b; 者 else return c; } /*无需额外存储空间, 只需两次比较*/ max(int a[3]) {int c,int i; c=a[0]; for(i=1;i<3;i++) if (a[i]>c) c=a[i]; return c; } /*需要两个额外的存储 空间,两次比较,至少 一次赋值*/ /*共需5个整型数空间*/
1345(元素1的存储地址)1400
每个结点都由两部分组成:数据域和指针域。 数据域存放元素本身的数据, 指针域存放指针(下一个元素的存储地址)。 数据元素之间逻辑上的联系由指针来体现。
1.3 算法和算法分析
1.3.1 算法
(1)定义 算法是对特定问题求解步骤的一种描述,它是指令的 有限序列,其中每一条指令表示一个或多个操作。 (2)算法的特性 有限性:算法必须在有限步内结束; 确定性:组成算法的操作必须清晰无二义性。 有效性:组成算法的操作必须能够在计算机上实现。 输入:0个或多个输入; 输出:1个或多个输出;
ListInsert(L,i,e) 基本操作 ListDelete(L,i,e)
...
1.2 数据结构
定义:数据结构是相互之间存在一种或多种
特定关系的数据元素的集合。
数据结构的形式化定义:数据结构是一个二 元组
Data_Structure = (D,S) 其中,D是数据元素的有限集合,S是D上 关系的集合。
1.3.3 算法的时间复杂度
事后测试的方法(性能度量); 事前分析估算的方法(性能分析); 事前估算法要考虑以下的因素: 问题的规模; 编写程序时所用的程序设计语言; 机器的速度; 算法所用的策略。
撇开这些与机器软硬件有关的因素,可以认为一个特定算法“运 行工作量”的大小只依赖与问题的规模,或者说只是问题规模的 函数。 算法由控制结构和原操作构成,其执行的时间取决于两者的综合 效果。
100个整数 同上的算法难写难读
/*共需102个整型数空 间*/
1.3.2 算法的性能分析与度量
算法性能度量的两个因素:时间复杂度和空间复杂度。 1. 时间复杂度是按某种算法设计的程序在计算机上执行 时花费的CPU时间的度量。 2. 空间复杂度是按某种算法设计的程序在计算机上执行 时需要使用的存储空间的度量。