数据结构复习大纲.docVIP

  1. 1、本文档共22页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构复习大纲

第1章 概述 1.概念和术语 数据:是能输入到计算机中并能被计算机程序处理的符号的总称。 数据元素:是数据的基本单位,它在计算机处理和程序设计中通常作为一个整体进行考虑和处理。一个数据元素可由若干数据项组成。 数据对象:是具有相同特征的数据元素的集合,是数据的一个子集。 数据结构:是数据元素的组织形式,或数据元素相互之间存在一种或多种特定关系的集合。 数据的逻辑结构:是指数据结构中数据元素之间的逻辑关系。 数据的存储结构:是数据的逻辑结构在计算机内存中的存储方式,又称物理结构。 数据类型:是一组具有相同性质的操作对象以及该组操作对象上的运算方法的集合。 抽象数据类型:是指一个数学模型以及在该模型上定义的一套运算规则的集合。 算法:建立在数据结构基础上的,为解决问题而采取的步骤和方法。 2.逻辑结构的四种基本形态 根据数据元素之间关系的不同特征,通常有下列四类基本结构: (1)集合:结构中的数据元素间除了“同属于一个集合”的关系外,别无其它关系。 (2)线性结构:结构中的数据元素之间存在一个对一个的关系。 (3)树型结构:结构中的数据元素之间存在一个对多个的关系。 (4)图型结构或网状结构:结构中的数据元素之间存在多个对多个的关系。 3.数据存储结构的基本组织方式 数据存储结构有顺序和链式两种方式。 (1)顺序存储结构的特点:要借助数据元素在存储器中的相应位置来体现数据元素相互间的逻辑关系,常用高级编程语言中的“一维数组”来描述或实现。 (2)链式存储结构的特点:通过表示数据元素存储地址的指针来表示数据元素之间的逻辑关系,通常用链表来实现。 在顺序存储结构的基础上,又可延伸变化出另外两种存储结构,即索引存储和散列存储。 (1)索引存储就是在数据文件的基础上增加了一个索引表文件。通过索引表建立索引,可以把一个顺序表分成几个顺序子表,其目的是在查询时提高查找效率,避免盲目查找。 (2)散列存储就是通过数据元素与存储地址之间建立起某种映射关系,使每个数据元素与每一个存储地址之间尽量达到一一对应的目的。这样,查找时同样可大大提高效率。 4.数据结构的研究内容 数据结构的核心研究内容包括三个方面:数据的逻辑结构、存储结构以及相应的基本操作运算的定义和实现。 5.算法的五个重要特征 (1)有穷性:一个算法必须保证在执行有限步骤之后结束,而不是无限的。 (2)确定性:算法中每一条指令必须有明确的含义,而不能是模棱两可的。 (3)可行性:每一个操作步骤都必须在有限的时间内完成。 (4)输入:一个算法可以有一个或多个输入,也可以没有输入。 (5)输出:一个算法可以有一个或多个输出。没有输出的算法是没有实际意义的。 6.算法的评价标准 (1)正确性。 (2)易读性。 (3)高效性。 (4)可维护性。 7.算法分析的目的 算法分析主要是指分析算法的效率。算法效率的度量主要从两个方面:算法的运行时间和算法所需的存储空间。分析的目的是通过考察算法的时间和空间效率,以求改进算法或对不同的算法进行比较。一般情况下,鉴于运算空间(内存)较为充足,所以把算法的时间复杂度分析作为重点。 8.算法的时间复杂度分析 (1)算法运算时间的度量的两种方法:事后统计的方法和事前分析估算的方法。 (2)算法运行时间的分析规则 通常把一个程序的运行时间定义为一个T(n)n)的单位是不确定的,一般把它看成在一个特定计算机上执行的指令条数。通常记作:T(n)=O(f(n)),其中f(n)表示数据输入规模。 常见的算法时间复杂度的形式按性能降序的排列如下: O(1)O()O(n)O(n*)O()O()O() 9.算法空间复杂度的含义 空间复杂度是对一个算法在运行过程中临时占用存储空间大小的量度。算法在计算机存储器内占用的存储空间主要分为三部分:算法源代码本身占用的存储空间;算法输入输出数据所占用的存储空间;算法运行过程中临时占用的存储空间。考虑一个算法的空间复杂度时,要综合分析这三个方面的因素。通常记作:S(n)=O(f(n)),其中n为问题的规模(或大小)。 第2、3章 线性表、栈、队列 1.线性表的定义 线性表是n个数据元素的有限序列,其中n(n≥0)为线性表的长度。 线性表中各个元素的类型相同。对于线性表(a1,a2,…,ai,…,an)而言,数据元素a1没有直接前趋,an没有直接后继,表中的其它元素ai(2≤i≤n-1)有且仅一个直接前趋ai-1和直接后继ai+1。 顺序表是指线性表的顺序存储结构,即用一组连续的存储单元依次存放线性表的数据元素。在C语言中可用一维数组来表示。在顺序表中,以数据元素在计算机内“物理位置相邻”来表示表中数据元素间的逻辑关系。 顺序表是一种随机存储结构,只要确定了存储顺序表的起始位置,则表中任一元素都可以随机存取。所以在顺序表中可以方便的进行

您可能关注的文档

文档评论(0)

tmd2017 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档