厦门大学数据结构复习的讲义.docVIP

  1. 1、本文档共13页,可阅读全部内容。
  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. 顺序存储结构:用一组连续的存储单元依次存储数据元素,数据元素之间的逻辑关系由元素的存储位置来表示。 2. 链接存储结构:用一组任意的存储单元存储数据元素,数据元素之间的逻辑关系用指针来表示 。 数据的操作:插入、删除、修改、检索、排序等 算法的相关概念 1.算法(Algorithm):是对特定问题求解步骤的一种描述,是指令的有限序列。 2. 算法的五大特性:√ ⑴ 输入:一个算法有零个或多个输入。 ⑵ 输出:一个算法有一个或多个输出。 ⑶ 有穷性:一个算法必须总是在执行有穷步之后结束,且每一步都在有穷时间内完成。 ⑷ 确定性:算法中的每一条指令必须有确切的含义,对于相同的输入只能得到相同的输出。 ⑸ 可行性:算法描述的操作可以通过已经实现的基本操作执行有限次来实现。 算法分析 算法分析(Algorithm Analysis):对算法所需要的计算机资源——时间和空间进行估算。 时间复杂性(Time Complexity) 空间复杂性(Space Complexity) for (i=1; i=n; i++) for (j=1; j=n; j++) x++; 问题规模:n 基本语句:x++ Ο(1)<Ο(log2n)<Ο(n)<Ο(nlog2n)<Ο(n2)<Ο(n3)<…<Ο(2n)<Ο(n!) 第二章 线性表:简称表,是n(n≥0)个具有相同类型的数据元素的有限序列。 线性表的长度:线性表中数据元素的个数。 1.有限性:线性表中数据元素的个数是有穷的。 2.相同性:线性表中数据元素的类型是同一的。 3.顺序性:线性表中相邻的数据元素ai-1和ai之间存在序偶关系(ai-1, ai),即ai-1是ai的前驱, ai是ai-1的后继;a1 无前驱,an无后继,其它每个元素有且仅有一个前驱和一个后继。 顺序表 一般情况下,(a1,a2,…, ai-1,ai , …, an)的顺序存储: ⑴ 无需为表中元素之间的逻辑关系而增加额外的存储空间; ⑵ 随机存取:可以快速地存取表中任一位置的元素。 ⑴ 插入和删除操作需要移动大量元素; ⑵ 表的容量难以确定,表的容量难以扩充; ⑶ 造成存储空间的碎片。 单链表 例:(a1, a2 ,a3, a4)的存储示意图 存储特点: 1.逻辑次序和物理次序不一定相同。 2.元素之间的逻辑关系用指针表示。 单链表的结点结构: 单链表 头结点:在单链表的第以一个元素结点之前附设一个类型相同的结点,以便空表和非空表处理统一。 空表 非空表 单链表的实现———删除 操作接口: T Delete(int i); √ 时间性能比较 时间性能是指实现基于某种存储结构的基本操作(即算法)的时间复杂度。 按位查找: 顺序表的时间为O(1),是随机存取; 单链表的时间为O(n),是顺序存取。 插入和删除: 顺序表需移动表长一半的元素,时间为O(n);单链表不需要移动元素,在给出某个合适位置的指针后,插入和删除操作所需的时间仅为O(1)。 第三章 栈的逻辑结构 栈:限定仅在表尾进行插入和删除操作的线性表。 空栈:不含任何数据元素的栈。 允许插入和删除的一端称为栈顶,另一端称为栈底。 栈的顺序存储结构及实现 栈的链接存储结构及实现 链栈:栈的链接存储结构 队列的逻辑结构 队列:只允许在一端进行插入操作,而另一端进行删除操作的线性表。 空队列:不含任何数据元素的队列。 允许插入(也称入队、进队)的一端称为队尾,允许删除(也称出队)的一端称为队头。 简单的整数顺序栈 1)初始化:int st[20],top=-1; 2)入栈: st[++top]; 3)出栈: st[top--]; 4)栈空: top==-1 简单的整数队列 1)初始化:int q[20],front=rear=-1; 2)入队: st[++rear]=x; 3)出队: x=st[++front]; 4)队空: front==re

文档评论(0)

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

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

1亿VIP精品文档

相关文档