二级-数据结构与算法_第1页
二级-数据结构与算法_第2页
二级-数据结构与算法_第3页
二级-数据结构与算法_第4页
二级-数据结构与算法_第5页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、计算机二级公共基础知识数据结构与算法1 算法算法:是指解题方案的准确而完整的描述。 算法不等于程序,也不等计算机方法,程序的编制不可能优于算法的设计。 算法的基本特征:是一组严谨地定义运算顺序的规则,每一个规则都是有效的,是明确的,此 顺序将在有限的次数下终止。特征包括:( 1)可行性;(2)确定性,算法中每一步骤都必须有明确定义,不充许有模棱两可的解释,不允许有多义 性;(3)有穷性,算法必须能在有限的时间内做完,即能在执行有限个步骤后终止,包括合理的 执行时间的含义;( 4 )拥有足够的情报。 算法的基本要素:一是对数据对象的运算和操作;二是算法的控制结构。 指令系统:一个计算机系统能执行

2、的所有指令的集合。基本运算和操作包括:算术运算、逻辑运算、关系运算、数据传输。 算法的控制结构:顺序结构、选择结构、循环结构。算法基本设计方法:列举法、归纳法、递推、递归、减斗递推技术、回溯法。 算法复杂度:算法时间复杂度和算法空间复杂度。算法时间复杂度是指执行算法所需要的计算工作量。 算法空间复杂度是指执行这个算法所需要的内存空间。2 数据结构的基本基本概念数据结构研究的三个方面:( 1)数据集合中各数据元素之间所固有的逻辑关系,即数据的逻辑结构;( 2)在对数据进行处理时,各数据元素在计算机中的存储关系,即数据的存储结构;( 3)对各种数据结构进行的运算。 数据结构是指相互有关联的数据元素

3、的集合。 数据的逻辑结构包含:( 1)表示数据元素的信息;( 2)表示各数据元素之间的前后件关系。 数据的存储结构有顺序、链接、索引等。线性结构条件:( 1 )有且只有一个根结点;( 2)每一个结点最多有一个前件,也最多有一个后件。 非线性结构:不满足线性结构条件的数据结构。3 线性表及其顺序存储结构线性表由一组数据元素构成,数据元素的位置只取决于自己的序号,元素之间的相对位置是线 性的。在复杂线性表中,由若干项数据元素组成的数据元素称为记录,而由多个记录构成的线性表又 称为文件。非空线性表的结构特征:( 1)且只有一个根结点 a1 ,它无前件;( 2)有且只有一个终端结点 an ,它无后件;

4、 (3)除根结点与终端结点外,其他所有结点有且只有一个前件,也有且只有一个后件。结点 个数 n 称为线性表的长度,当 n=0 时,称为空表。线性表的顺序存储结构具有以下两个基本特点:( 1 )线性表中所有元素的所占的存储空间是连续的;( 2)线性表中各数据元素在存储空间中是按逻辑顺序依次存放的。ai 的存储地址为: adr(ai)=adr(a1)+(i-1)k, , adr(a1) 为第一个元素的地址, k 代表每个元素占的 字节数。顺序表的运算:插入、删除。 (详见 14-16 页)4 栈和队列栈是限定在一端进行插入与删除的线性表,允许插入与删除的一端称为栈顶,不允许插入与删 除的另一端称为

5、栈底。栈按照“先进后出”(filo )或“后进先出” (lifo )组织数据,栈具有记忆作用。用top表示栈顶位置,用 bottom 表示栈底。栈的基本运算: ( 1 )插入元素称为入栈运算; ( 2 )删除元素称为退栈运算; ( 3)读栈顶元素是 将栈顶元素赋给一个指定的变量,此时指针无变化。队列是指允许在一端(队尾)进入插入,而在另一端(队头)进行删除的线性表。rear 指针指向队尾, front 指针指向队头。队列是“先进行出”(fifo )或“后进后出” (lilo)的线性表。队列运算包括( 1)入队运算:从队尾插入一个元素;( 2)退队运算:从队头删除一个元素。循环队列: s=0 表

6、示队列空, s=1 且 front=rear 表示队列满5 线性链表数据结构中的每一个结点对应于一个存储单元,这种存储单元称为存储结点,简称结点。 结点由两部分组成: ( 1)用于存储数据元素值, 称为数据域;( 2)用于存放指针, 称为指针域, 用于指向前一个或后一个结点。在链式存储结构中,存储数据结构的存储空间可以不连续,各数据结点的存储顺序与数据元素 之间的逻辑关系可以不一致,而数据元素之间的逻辑关系是由指针域来确定的。链式存储方式即可用于表示线性结构,也可用于表示非线性结构。线性链表, head 称为头指针, head=null (或 0)称为空表,如果是两指针:左指针( llink

7、)指 向前件结点,右指针( rlink )指向后件结点。线性链表的基本运算:查找、插入、删除。6 树与二叉树树是一种简单的非线性结构,所有元素之间具有明显的层次特性。 在树结构中,每一个结点只有一个前件,称为父结点,没有前件的结点只有一个,称为树的根 结点,简称树的根。每一个结点可以有多个后件,称为该结点的子结点。没有后件的结点称为叶子 结点。在树结构中, 一个结点所拥有的后件的个数称为该结点的度, 所有结点中最大的度称为树的度。 树的最大层次称为树的深度。二叉树的特点: ( 1)非空二叉树只有一个根结点; ( 2)每一个结点最多有两棵子树,且分别称 为该结点的左子树与右子树。二叉树的基本性质

8、:(1) 在二叉树的第k层上,最多有2k-1(k 1)个结点;( 2)深度为 m 的二叉树最多有 2m-1 个结点;( 3)度为 0 的结点(即叶子结点)总是比度为 2 的结点多一个;(4) 具有n个结点的二叉树,其深度至少为Iog2n+1,其中Iog2n表示取Iog2n的整数部分;( 5)具有 n 个结点的完全二叉树的深度为 log2n+1 ;(6)设完全二叉树共有 n 个结点。如果从根结点开始, 按层序(每一层从左到右) 用自然数 1, 2,, .n给结点进行编号(k=1,2 , .n),有以下结论: 若 k=1 ,则该结点为根结点,它没有父结点;若 k1 ,则该结点的父结点编号为 int

9、(k/2) ; 若2k n,则编号为k的结点的左子结点编号为 2k ;否则该结点无左子结点(也无右子结点); 若2k+1 0)个元素构成的有限序列(al , a2 , , , an)。表中的每一个数据元素,除 了第一个外,有且只有一个前件,除了最后一个外,有且只有一个后件。即线性表是一个空表,或 可以表示为(a1 , a2, , , an)其中ai(i=1,2,,, n)是属于数据对象的元素,通常也称其为线性表中的一个结点。 其中,每个元素可以简单到是一个字母或是一个数据,也可能是比较复杂的由多个数据项 组成的。在复杂的线性表中,由若干数据项组成的数据元素称为记录(record) ,而由多个记

10、录构成的线性表又称为文件 (fiIe) 。在非空表中的每个数据元素都有一个确定的位置,如 a1 是第一个元素, an 是最后一个数据元素, ai 是第 i 个数据元素,称 i 为数据元素 ai 在线性表中的位序。非空线性表 有如下一些结构特征:(1) 有且只有一个根结点 a1 ,它无前件;(2) 有且只有一个终端结点 an,它无后件;(3) 除根结点与终端结点外,其他所有结点有且只有一个前件,也有且只有一个后件。线性表 中结点的个数 n 称为线性表的长度。当 n=0 时称为空表。考点 7 线性表的顺序存储结构线性表的顺序表指的是用一组地址连续的存储单元依次存储线性表的数据元素。线性表的顺序存储

11、结构具备如下两个基本特征:(1) 线性表中的所有元素所占的存储空间是连续的;(2) 线性表中各数据元素在存储空间中是按逻辑顺序依次存放的。假设线性表的每个元素需要占用k个存储单元,并以所占的存储位置ADR(ai+1)和第i个数据元素的存储位置 ADR(ai) 之间满足下列关系:ADR(ai+1)=ADR(ai)+k线性表第 i 个元素 ai 的存储位置为ADR(ai)=ADR(a1)+(i-1) x k式中ADR(ai)是线性表的第一个数据元素a,的存储位置,通常称做线性表的起始位置或基址。线性表的这种表示称做线性表的顺序存储结构或顺序映像,这种存储结构的线性表为顺序 表。表中每一个元素的存储

12、位置都和线性表的起始位置相差一个和数据元素在线性表中的位序成正 比例的常数。如图 1-4 所示。由此只要确定了存储线性表的起始位置,线性表中任一数据元素都可 以随机存取,所以线性表的顺序存储结构是一种随机存取的存储结构。在程序设计语言中,通常定义一个一维数组来表示线性表的顺序存储空间。在用一维数组存放 线性表时,该一维数组的长度通常要定义得比线性表的实际长度大一些,以便对线性表进行各种运算,特别是插入运算。在线性表的顺序存储结构下,可以对线性表做以下运算:(l) 在线性表的指定位置处加入一个新的元素(即线性表的插入 );(2) 在线性表中删除指定的元素 (即线性表的删除 );(3) 在线性表中

13、查找某个 (或某些 )特定的元素 (即线性表的查找 );(4) 对线性表中的元素进行整序 (即线性表的排序 );(5) 按要求将一个线性表分解成多个线性表(即线性表的分解 );(6) 按要求将多个线性表合并成一个线性表(即线性表的合并 );(7) 复制一个线性表 (即线性表的复制 );(8) 逆转一个线性表 (即线性表的逆转 )等。考点 8 顺序表的插入运算线性表的插入运算是指在表的第i(1 Next指向ai的 直接后件结点,即把 ai 从链上摘下。最后释放结点 a 的空间。从线性链表的删除过程可以看出,从线性链表中删除一个元素后,不需要移动表中的数据 元素,只要改变被删除元素所在结点的前一个

14、结点的指针域即可。另外,由于可利用栈是用于收集 计算机中所有的空闲结点, 因此, 当从线性链表中删除一个元素后, 该元素的存储结点就变为空闲, 应将空闲结点送回到可利用栈。考点 14 线性双向链表的结构及其基本运算1 什么是双向链表在单链表中,从某个结点出发可以直接找到它的直接后件,时间复杂度为 0(1),但无法直接找到它的互接前件;在单循环链表中,从某个结点出发可以直接找到它的直接后件,时间复杂度 仍为0(1),直接找到它的直接前件,时间复杂度为0(n)。有时,希望能快速找到一个结点的直接前件,这时,可以在单链表中的结点中增加一个指针域指向它的直接前件,这样的链表,就称为双向链表 (一个结点

15、中含有两个指针 )。如果每条链构成一个循环链表,则会得到双向循环链表2 双向链表的基本运算(l) 插入:在 HEAD 为头指针的双向链表中,在值为 Y 的结点之后插入值为 X 的结点,插 入结点的指针变化。 如图 1-20 所示(若改为在值为 Y 的结点之前插入值为 X 的结点, 可以做类似分 析)。(2)删除:在以HEAD为头指针的双向链表中删除值为X的结点,删除算法的指针变化,如图 1-21 所示。考点 15 循环链表的结构及其基本运算 单链表上的访问是一种顺序访问,从其中的某一个结点出发,可以找到它的直接后件,但 无法找到它的直接前件。在前面所讨论的线性链表中,其插入与删除的运算虽然比较

16、方便,但还存在一个问题,在 运算过程中对于空表和对第一个结点的处理必须单独考虑,使空表与非空表的运算不统一。因此,我们可以考虑建立这样的链表,具有单链表的特征,但又不需要增加额外的存贮空 间,仅对表的链接方式稍做改变,使得对表的处理更加方便灵活。从单链表可知,最后一个结点的 指针域为 NULL ,表示单链表已经结束。如果将单链表最后一个结点的指针域改为存放链表中头结 点 (或第一个结点 )的地址,就使得整个链表构成一个环,又没有增加额外的存储空间循环链表具有以下两个特点:(1) 在循环链表中增加了一个表头结点,其数据域为任意或者根据需要来设置, 指针域指向线性表的第一个元素的结点。循环链表的头

17、指针指向表头结点;(2) 循环链表中最后一个结点的指针域不是空,而是指向表头结点。即在循环链表中,所有 结点的指针构成了一个环状链。在循环链表中,只要指出表中任何一个结点的位置,就可以从它出发访问到表中其他所有 的结点,而线性单链表做不到这一点。由于在循环链表中设置了一个表头结点,因此,在任何情况下,循环链表中至少有一个结 点存在,从而使空表的运算统一。1.6 树与二叉树考点 16 树的定义树是由n( n 0)个结点组成的有限集合。若n =0 ,称为空树;若n0 ,则:(1) 有一个特定的称为根(root)的结点。它只有直接后件,但没有直接前件;(2) 除根结点以外的其他结点可以划分为m(m

18、0)个互不相交的有限集合 T0 , T1 ,Tm-1,每个集合Ti(i=0 , 1, , , m-l)又是一棵树,称为根的子树,每棵子树的根结点有且仅有一个 直接前件,但可以有 0 个或多个直接后件。树型结构具有如下特点:(1) 助每个结点只有一个前件,称为父结点,没有前件的结点只有一个,称为树的根结 点,简称为树的根;(2) 每一个结点可以有多个后件,它们都称为该结点的子结点。 没有后件的结点称为叶子结点;(3) 一个结点所拥有的后件个数称为树的结点度;(4) 树的最大层次称为树的深度。 在计算机中,可以用树结构来表示算术表达式,用树来表示算术表达式的原则是:(1) 表达式中的每一个运算符在

19、树中对应一个结点,称为运算符结点;(2) 运算符的每一个运算对象在树中为该运算符结点的子树(在树中的顺序为从左到右);(3) 运算对象中的单变量均为叶子结点。树在计算机中通常用多重链表表示。考点 17 二叉树的定义及其基本性质1 什么是二叉树二叉树(binary tree)是由n( 0)个结点的有限集合构成,此集合或者为空集,或者由一个根结点及两棵互不相交的左右子树组成,并且左右子树都是二叉树。二叉树可以是空集合,根可以有 空的左子树或空的右子树。二叉树不是树的特殊情况,它们是两个概念。二叉树具有如下两个特点:(1) 非空二叉树只有一个根结点;(2) 每一个结点最多有两棵子树,且分别称为该结点

20、的左子树与右子树。二叉树的每个结点最多有两个孩子,或者说,在二叉树中,不存在度大于2 的结点,并且二叉树是有序树 (树为无序树 ),其子树的顺序不能颠倒,因此,二叉树有 5 种不同的形态 在二叉树中,一个结点可以只有左子树而没有右子树,也可以只有右子树而没有左子树。 当一个结点既没有左子树也没有右子树时,该结点即是叶子结点)2 二叉树的基本性质性质1 :在二叉树的第入层上至多有2k-1个结点(k 1)。性质 2:深度为 m 的二叉树至多有 2m-1 个结点。深度为 m 的二叉树的最大的结点数是为二叉树中每层上的最大结点数之和,由性质 1 得到最大结点数。性质 3:对任何一棵二叉树,度为 0 的

21、结点 (即叶子结点 )总是比度为 2 的结点多一个。如果叶子结点n0,度为2的结点数为n2,则n0=n2+1。设二叉树中度为1的结点数为n1,二叉树中总结点数为 N,因为二叉树中所有结点均小于 或等于 2,所以有N=n0+n1+n(1)再看二叉树中的分支数, 除根结点外, 其余结点都有一个进入分支, 设 m 为二叉树中的分 支总数,则有N=m+1(2)又由于二叉树中这 m 个分支是分别由非叶子结点射出的。其中度为 1 的每个结点射出 1 个分支,度为 2的每个结点射出 2个分支。因此,二叉树中所有度为 1 与度为 2 的结点射出的分支 总数为 n1+2n2 ,而在二叉树中,总的射出分支数应与总

22、的进入分支数相等,即m=n1+2n2(3)将(3)代入(2)式有N=n1+2n2+1比较(1)和(4)并化简得n0=n2+1性质4 :具有n个结点的完全二叉树的深度至少为Iog2n+ 1 ,其中Iog2n表示Iog2n的整数部分。3 满二叉树与完全二叉树(l)满二叉树 满二叉树是指这样的一种二叉树:除最后一层外,每一层上的所有结点都有两个子结点。 深度为 k 的二叉树具有 2k-1 个结点。即在满二叉树的第 k 层上有 2k-1 个结点。从上面满二叉树定义可知,必须是二叉树的每一层上的结点数都达到最大,否则就不是满二叉树。深度为 m 的满二叉树有 2m-1 个结点。(2)完全二叉树 完全二叉树

23、是指这样的二叉树:除最后一层外,每一层上的结点数均达到最大值;在最后 一层上只缺少右边的若干结点。如果一棵具有 n 个结点的深度为 k 的二叉树, 它的每一个结点都与深度为 k 的满二叉树中编号 为 1n 的结点一一对应。为满二叉树和完全二叉树的结构比较。从完全二叉树定义可知, 结点的排列顺序遵循从上到下、 从左到右的规律。 所谓从上到下, 表示本层结点数达到最大后,才能放入下一层。从左到右,表示同一层结点必须按从左到右排列, 若左边空一个位置时不能将结点放入右边。完全二叉树除最后一层外每一层的结点数都达到最大 值,最后一层只缺少右边的若干结点。满二叉树也是完全二叉树,反之完全二叉树不一定是满二叉树。性质5 :具有n个结点的完全二叉树深度为 Iog2n+ 1或Iog2(n+1)。性质 6:如果对一棵有 n 个结点的完全二叉树的结点按层序编号(从第 1 层到第 log2n+1层,每层从

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论