ImageVerifierCode 换一换
格式:DOCX , 页数:61 ,大小:363.22KB ,
资源ID:18311558      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/18311558.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(2331数据结构各章要点Word文档下载推荐.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

2331数据结构各章要点Word文档下载推荐.docx

1、(1)逻辑结构 表中的每一行是一个数据元素(或记录、结点),它由学号、姓名、各科成绩及平均成绩等数据项组成。表中数据元素之间的逻辑关系是:对表中任一个结点,与它相邻且在它前面的结点(亦称为直接前趋(Immediate Predecessor)最多只 有一个;与表中任一结点相邻且在其后的结点(亦称为直接后继(Immediate Successor)也最多只有一个。表中只有第一个结点没有直 接前趋,故称为开始结点;也只有最后一个结点没有直接后继。故称之为终端结点。例如,表中马二所在结点的直接前趋结点和直接后继 结点分别是丁一和张三所在的结点,上述结点间的关系构成了这张学生成绩表的逻辑结构。(2)存

2、储结构 该表的存储结构是指用计算机语言如何表示结点之间的这种关系,即表中的结点是顺序邻接地存储在一片连续的单元之中,还是用指针将 这些结点链接在一起?(3)数据的运算 在上面的学生成绩表中,可能要经常查看某一学生的成绩;当学生退学时要删除相应的结点;进来新学生时要增加结点。究竟如何进行查 找、删除、插入,这就是数据的运算问题。搞清楚了上述三个问题,也就弄清了学生成绩表这个数据结构。2 数据的逻辑结构分类 在不产生混淆的前提下,常将数据的逻辑结构简称为数据结构。数据的逻辑结构有两大类:( 1)线性结构 线性结构的逻辑特征 是:若结构是非空集,则有且仅有一个开始结点和一个终端 结点,并且所有结点都

3、最多只有一个直接前趋和一个直接后 继。 线性表是一个典型的线性结构。栈、队列、串等都是线性结构。( 2)非线性结构 非线性结构的逻辑特征 是:一个结点可能有多个直接前趋和直接后继。数组、广义表、树和图等数据结构都是非线性结构。概论- 基本概念和术语(二)3 数据的四种基本存储方法 数据的存储结构可用以下四种基本存储方法得到:( 1 )顺序存储方法 该方法把逻辑上相邻的结点存储在物理位置上相邻的存储单元里,结点间的逻辑关系由存储单元的邻接关系来体现。由此得到的存储表示称为顺序存储结构 ( Sequential Storage Structure ),通常借助程序语言的数组描述。该方法主要应用于线

4、性的数据结构。非线性的数据结构也可通过某种线性化的方法实现顺序存储。( 2 )链接存储方法 该方法不要求逻辑上相邻的结点在物理位置上亦相邻,结点间的逻辑关系由附加的指针字段表示。由此得到的存储表示称为链式存储结构( Linked Storage Structure ) , 通常借助于程序语言的指针类型描述。(3) 索引存储方法 该方法通常在储存结点信息的同时 , 还建立附加的索引表。索引表由若干索引项组成。若每个结点在索引表中都有一个索引项,则该索引表称之为稠密索引( Dense Index )。若一组结点在索引表中只对应一个索引项,则该索引表称为稀疏索引 (Spare Index) 。 索引

5、项的一般形式是:( 关键字、地址 ) 关键字是能唯一标识一个结点的那些数据项。稠密索引中索引项的地址指示结点所在的存储位置;稀疏索引中索引项的地址指示一组结点的起始存储位置。(4) 散列存储方法 该方法的基本思想是:根据结点的关键字直接计算出该结点的存储地址。四种基本存储方法,既可单独使用,也可组合起来对数据结构进行存储映像。同一逻辑结构采用不同的存储方法,可以得到不同的存储结构。选择何种存储结构来表示相应的逻辑结构,视具体要求而定,主要考虑运算方便及算法的时空要求。4 数据结构三方面的关系 数据的逻辑结构、数据的存储结构及数据的运算这三方面是一个整体。孤立地去理解一个方面,而不注意它们之间的

6、联系是不可取的。存储结构是数据结构不可缺少的一个方面:同一逻辑结构的不同存储结构可冠以不同的数据结构名称来标识。【例】线性表是一种逻辑结构,若采用顺序方法的存储表示,可称其为顺序表;若采用链式存储方法,则可称其为链表;若采用散列存储方法,则可称为散列表。数据的运算也是数据结构不可分割的一个方面。在给定了数据的逻辑结构和存储结构之后,按定义的运算集合及其运算的性质不同,也可能导致完全不同的数据结构。【例】 若对线性表上的插入、删除运算限制在表的一端进行,则该线性表称之为栈;若对插入限制在表的一端进行,而删除限制在表的另一端进行,则该线性表称之为队列。更进一步,若线性表采用顺序表或链表作为存储结构

7、,则对插入和删除运算做了上述限制之后,可分别得到顺序栈或链栈,顺序队列或链队列。数据类型(Data Type) 所谓数据类型是一个值的集合以及在这些值上定义的一组操作的总称。通常数据类型可以看作是程序设计语言中已实现的数据结构。【例12】C语言的整数类型就定义了一个整数可取值的范围(其最大值INT-MAX依赖于具体机器)以及对整数可施加的加、减、乘、除和取模等操作。按值是否可分解,可将数据类型划分为两类: 原子类型 :其值不可分解。通常是由语言直接提供。【例】 C语言的整型、字符型等标准类型及指针等简单的导出类型; 结构类型 :其值可分解为若干个成分(或称为分量)。是用户借助于语言提供的描述机

8、制自己定义的,它通常是由标准类型派生的,故它也是一种导出类型。【例】 C的数组、结构等类型。抽象数据类型(Abstract Type简称ADT) ADT是指抽象数据的组织和与之相关的操作。可以看作是数据的逻辑结构及其在逻辑结构上定义的操作。一个ADT可描述为:ADT ADT-Name Data:/数据说明 数据元素之间逻辑关系的描述 Operations:/操作说明 Operation1:/操作1,它通常可用C或C的函数原型来描述 Input:对输入数据的说明 Preconditions:执行本操作前系统应满足的状态/可看作初始条件 Process:对数据执行的操作 Output:对返回数据的

9、说明 Postconditions:执行本操作后系统的状态/系统可看作某个数据结构 Operation2:/操作2 /ADT 抽象数据类型可以看作是描述问题的模型,它独立于具体实现。它的优点是将数据和操作封装在一起,使得用户程序只能通过在ADT里定义的某些操作来访问其中的数据,从而实现了信息隐藏。在C中,我们可以用类(包括模板类)的说明来表示ADT,用类的实现来实现ADT【参阅10】。因此,C中实现的类相当于是数据的存储结构及其在存储结构上实现的对数据的操作。 ADT和类的概念实际上反映了程序或软件设计的两层抽象:ADT相当于是在概念层(或称为抽象层)上描述问题,而类相当于是在实现层上描述问题

10、。此外,C中的类只是一个由用户定义的普通类型,可用它来定义变量(称为对象或类的实例)。因此,在C中,最终是通过操作对象来解决实际问题的,所以我们可将该层次看作是应用层。例如,main程序就可看作是用户的应用程序。 由于C语言中没有提供类这一数据类型,因此无法实现ADT,故我们不采用ADT的形式来描述数据结构,以节省篇幅。大家只要记住,它实际上等价于我们定义的数据的逻辑结构以及在逻辑结构上定义的抽象操作。概论- 算法的描述和分析(一) 数据的运算通过算法(Algorithm)描述,讨论算法是数据结构课程的重要内容之一。1算法 非形式地说,算法是任意一个良定义的计算过程。它以一个或多个值作为输入,

11、并产生一个或多个值作为输出。(1)一个算法可以被认为是用来解决一个计算问题的工具。(2)一个算法是一系列将输入转换为输出的计算步骤。【例31】有这样一个排序问题:将一个数字序列排序为非降序。该问题的形式定义由满足下述关系的输入输出序列构成:输入:数字序列a 1 ,a 2 ,a n 。输出:输出序列的一个枚举a 1 ,a 2 ,,a n 使得a 1 a 2 a 3 对于一个输入实例31,41,59,26,41,58,排序算法应返回输出序列26,31,41,41,58,59。(1)输入实例 输入实例:一个问题的输入实例是满足问题陈述中所给出的限制、为计算该问题的解所需要的所有输入构成的。(2)正确

12、的算法和不正确的算法 若一个算法对于每个输入实例均能终止并给出正确的结果,则称该算法是正确的。正确的算法解决了给定的计算问题。一个不正确的算法是指对某些输入实例不终止,或者虽然终止但给出的结果不是所渴望得到的答案,一般只考虑正确的算法。2算法的描述 一个算法可以用自然语言、计算机程序语言或其它语言来说明,惟一的要求是该说明必须精确地描述计算过程。 一般而言,描述算法最合适的语言是介于自然语言和程序语言之间的伪语言。它的控制结构往往类似于Pascal、C等程序语言,但其中可使用任何表达能力强的方法使算法表达更加清晰和简洁,而不至于陷入具体的程序语言的某些细节。 从易于上机验证算法和提高实际程序设

13、计能力考虑,采用C语言描述算法。【例32】定义一个输出错误信息后退出程序运行的错误处理函数,该函数将在后续的许多程序中用来简化处理代码。# include /其中有exit的说明 stdio.h /其中有标准错误stderr的说明 void Error(char*message) fprintf(stderr,Error: % s n , message) ; /输出错误信息 exit(1) ; /终止程序,返回1给操作系统 概论- 算法的描述和分析(二)算法分析 1评价算法好坏的标准 求解同一计算问题可能有许多不同的算法,究竟如何来评价这些算法的好坏以便从中选出较好的算法呢?选用的算法首先应

14、该是正确的。此外,主要考虑如下三点: 执行算法所耗费的时间; 执行算法所耗费的存储空间,其中主要考虑辅助存储空间; 算法应易于理解,易于编码,易于调试等等。2算法性能选择 一个占存储空间小、运行时间短、其它性能也好的算法是很难做到的。原因是上述要求有时相互抵触:要节约算法的执行时间往往要以牺牲更多的空间为代价;而为了节省空间可能要耗费更多的计算时间。因此我们只能根据具体情况有所侧重: 若该程序使用次数较少,则力求算法简明易懂; 对于反复多次使用的程序,应尽可能选用快速的算法; 若待解决的问题数据量极大,机器的存储空间较小,则相应算法主要考虑如何节省空间。3算法的时间性能分析 (1)算法耗费的时

15、间和语句频度 一个算法所耗费的时间=算法中每条语句的执行时间之和 每条语句的执行时间=语句的执行次数(即频度(Frequency Count)语句执行一次所需时间 算法转换为程序后,每条语句执行一次所需的时间取决于机器的指令性能、速度以及编译所产生的代码质量等难以确定的因素。若要独立于机器的软、硬件系统来分析算法的时间耗费,则设每条语句执行一次所需的时间均是单位时间,一个算法的时间耗费就是该算法中所有语句的频度之和。【例3.3】求两个n阶方阵的乘积 C=AB,其算法如下:# define n 100 / n 可根据需要定义,这里假定为100 void MatrixMultiply(int Aa

16、,int B nn,int Cnn) /右边列为各语句的频度 int i ,j ,k;(1) for(i=0; in;j+) n+1 (2) for (j=0;jn;j+) n(n+1) (3) Cij=0; n 2 (4) for (k=0; kn; k+) n 2 (n+1) (5) Cij=Cij+Aik*Bkj; n 3 该算法中所有语句的频度之和(即算法的时间耗费)为:T(n)=2n 3 +3n 2 +2n+1 (1.1) 分析: 语句(1)的循环控制变量i要增加到n,测试到i=n成立才会终止。故它的频度是n+1。但是它的循环体却只能执行n次。语句(2)作为语句(1)循环体内的语句应

17、该执行n次,但语句(2)本身要执行n+1次,所以语句(2)的频度是n(n+1)。同理可得语句(3),(4)和(5)的频度分别是n 2 ,n 2 (n+1)和n 3 。 算法MatrixMultiply的时间耗费T(n)是矩阵阶数n的函数。(2)问题规模和算法的时间复杂度 算法求解问题的输入量称为问题的规模(Size),一般用一个整数表示。【例34】矩阵乘积问题的规模是矩阵的阶数。【例35】一个图论问题的规模则是图中的顶点数或边数。 一个算法的时间复杂度(Time Complexity, 也称时间复杂性)T(n)是该算法的时间耗费,是该算法所求解问题规模n的函数。当问题的规模n趋向无穷大时,时间

18、复杂度T(n)的数量级(阶)称为算法的渐进时间复杂度。【例36】算法MatrixMultidy的时间复杂度T(n)如(1.1)式所示,当n趋向无穷大时,显然有 这表明,当n充分大时,T(n)和n 3 之比是一个不等于零的常数。即T(n)和n 3 是同阶的,或者说T(n)和n 3 的数量级相同。记作T(n)=O(n 3)是算法MatrixMultiply的渐近时间复杂度。数学符号O的严格的数学定义:若T(n)和f(n)是定义在正整数集合上的两个函数,则T(n)=O(f(n)表示存在正的常数C和n0,使得当nn0时都满足0T(n)Cf(n)。概论- 算法的描述和分析(三)(3)渐进时间复杂度评价算

19、法时间性能 主要用算法时间复杂度的数量级(即算法的渐近时间复杂度)评价一个算法的时间性能。【例37】有两个算法A 1 和A 2 求解同一问题,时间复杂度分别是T 1 (n)=100n 2 ,T 2 (n)=5n 3 。(1)当输入量n20时,有T 1 (n)T 2 (n),后者花费的时间较少。(2)随着问题规模n的增大,两个算法的时间开销之比5n 3 /100n 2 =n/20亦随着增大。即当问题规模较大时,算法A 1 比算法A 2 要有效地多它们的渐近时间复杂度O(n 2 )和O(n 3 )从宏观上评价了这两个算法在时间方面的质量。在算法分析时,往往对算法的时间复杂度和渐近时间复杂度不予区分

20、,而经常是将渐近时间复杂度T(n)=O(f(n)简称为时间复杂度,其中的f(n)一般是算法中频度最大的语句频度。【例38】算法MatrixMultiply的时间复杂度一般为T(n)=O(n 3 ),f(n)=n 3 是该算法中语句(5)的频度。下面再举例说明如何求算法的时间复杂度。【例39】交换i和j的内容。Temp=i;i=j;j=temp; 以上三条单个语句的频度均为1,该程序段的执行时间是一个与问题规模n无关的常数。算法的时间复杂度为常数阶,记作T(n)=O(1)。如果算法的执行时间不随着问题规模n的增加而增长,即使算法中有上千条语句,其执行时间也不过是一个较大的常数。此类算法的时间复杂

21、度是O(1)。【例310】变量计数之一。(1) x=0;y=0;(2) for(k-1;k=n;k+) (3) x+;(4) for(i=1;ii+) (5) for(j=1;j=0&(Ai!=k) (3) i-;(4)return i;此算法中的语句(3)的频度不仅与问题规模n有关,还与输入实例中A的各元素取值及K的取值有关:若A中没有与K相等的元素,则语句(3)的频度f(n)=n;若A的最后一个元素等于K,则语句(3)的频度f(n)是常数0。(5)最坏时间复杂度和平均时间复杂度 最坏情况下的时间复杂度称最坏时间复杂度。一般不特别说明,讨论的时间复杂度均是最坏情况下的时间复杂度。这样做的原因

22、是:最坏情况下的时间复杂度是算法在任何输入实例上运行时间的上界,这就保证了算法的运行时间不会比任何更长。【例319】查找算法【例18】在最坏情况下的时间复杂度为T(n)=0(n),它表示对于任何输入实例,该算法的运行时间不可能大于0(n)。平均时间复杂度是指所有可能的输入实例均以等概率出现的情况下,算法的期望运行时间。常见的时间复杂度按数量级递增排列依次为:常数0(1)、对数阶0(log 2 n)、线形阶0(n)、线形对数阶0(nlog 2 n)、平方阶0(n 2 )立方阶0(n 3 )、k次方阶0(n k )、指数阶0(2 n )。显然,时间复杂度为指数阶0(2 n )的算法效率极低,当n值

23、稍大时就无法应用。类似于时间复杂度的讨论,一个算法的空间复杂度(Space Complexity)S(n)定义为该算法所耗费的存储空间,它也是问题规模n的函数。渐近空间复杂度也常常简称为空间复杂度。算法的时间复杂度和空间复杂度合称为算法的复杂度。顺序表顺序表 1 顺序表的定义 (1) 顺序存储方法 即把线性表的结点按逻辑次序依次存放在一组地址连续的存储单元里的方法。(2) 顺序表(Sequential List) 用顺序存储方法存储的线性表简称为顺序表(Sequential List)。2 结点ai 的存储地址 不失一般性,设线性表中所有结点的类型相同,则每个结点所占用存储空间大小亦相同。假设

24、表中每个结点占用c个存储单元,其中第一个单元的存储地址则是该结点的存储地址,并设表中开始结点a1的存储地址(简称为基地址)是LOC(a1),那么结点ai的存储地址LOC(ai)可通过下式计算: LOC(ai)= LOC(a1)+(i-1)*c 1in 在顺序表中,每个结点ai的存储地址是该结点在表中的位置i的线性函数。只要知道基地址和每个结点的大小,就可在相同时间内求出任一结点的存储地址。是一种随机存取结构。3顺序表类型定义 #define ListSize 100 /表空间的大小可根据实际需要而定,这里假设为100 typedef int DataType; /DataType的类型可根据实

25、际情况而定,这里假设为int typedef struct DataType dataListSize;/向量data用于存放表结点 int length;/当前的表长度 SeqList; 用向量这种顺序存储的数组类型存储线性表的元素外,顺序表还应该用一个变量来表示线性表的长度属性,因此用结构类型来定义顺序表类型。 存放线性表结点的向量空间的大小ListSize应仔细选值,使其既能满足表结点的数目动态增加的需求,又不致于预先定义过大而浪费存储空间。 由于C语言中向量的下标从0开始,所以若L是SeqList类型的顺序表,则线性表的开始结点a1和终端结点an分别存储在Ldata0和LDataLlength-1中。 若L是SeqList类型的指针变量,则a1和an分别存储在L-data0和L-dataL-length-1中。4顺序表的特点 顺序表是用向量实现的线性表,向量的下标可以看

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1