数据结构与算法课件.pptx
《数据结构与算法课件.pptx》由会员分享,可在线阅读,更多相关《数据结构与算法课件.pptx(135页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、数据结构与算法Data Structure and Algorithm数据结构是一门研究非数值计算的程序设计问题中的操作对象,以及它们之间的关系和操作等相关问题的学科。1968 Donald E.Knuth“The Art of Computer Programming”http:/www-cs-faculty.stanford.edu/uno/计算机排版系统TEX程序设计 =数据结构+算法数据:描述客观事物的符号,是计算机中可以操作的对象,是能被计算机识别,并输入给计算机处理的符号集合。数据元素:组成数据的、有一定意义的基本单位,在计算机中通常作为整体处理。也被称为记录。数据项:一个数据元素
2、可以由若干数据项组成。数据对象:性质相同的数据元素的集合,是数据的子集。数据数据对象数据元素数据项数据项数据项数据项数据元素不同数据元素之间不是独立的,而是存在特定的关系,将这些关系称为结构。数据结构:相互之间存在一种或多种特定关系的数据元素的集合逻辑结构:数据对象中数据元素之间的相互关系物理结构:是指数据的逻辑结构在计算机中的存储形式。示意图表示数据逻辑结构:将每一个数据元素看作一个结点,用圆圈表示。元素之间的逻辑关系用结点之间的连线表示,如果这个关系是有方向的,那么用带箭头的连线表示。集合结构:集合结构中的数据元素,除了同属于一个集合外,它们之间没有其他关系。线性结构:线性结构中的数据元素
3、之间是一对一的关系。树形结构:树形结构中的数据元素之间存在一对多的层次关系。图形结构:图形结构的数据元素是多对多的关系物理结构顺序存储结构:是把数据元素存放在地址连续的存储单元里,其数据间的逻辑关系和物理关系是一致的。链式存储结构:是把数据元素存放在任意的存储单元里,这组存储单元可以是连续的,也可以是不连续的。逻辑结构是面向问题的,物理结构是面向计算机的。物理结构的基本目的就是将数据及其逻辑关系存储到计算机的内存中。逻辑结构构物理物理结构构集合集合结构构线性性结构构树形形结构构图形形结构构顺序存序存储结构构链接存接存储结构构算法:解决特定问题求解步骤的描述,在计算机中表现为指令的有限序列,并且
4、每条指令表示一个或多个操作。算法的特性输入:具有零个或多个输入输出:至少有一个或多个输出有穷性:算法在执行有限的步骤之后,自动结束而不会出现无线循环。确定性:算法的每一步都具有确定的含义,不会出现二义性。可行性:算法的每一步都是可行的,即每一步都能通过执行有限次数完成。Thomas H.Cormen,Chales E.Leiserson(2009)第三版“直白的说,算法就是任何明确定义的计算过程,它接收一些值或集合作为输入,并产生一些值或集合作为输出。这样,算法就是将输入转换为输出的一系列计算过程”简而言之,我们可以说算法就是用来解决一个特定任务的一系列步骤。一个有效的算法应该含有三个重要特性
5、:1 它必须是有限的:如果你设计的算法永无休止的尝试解决问题,那么它是无用的。2 它必须具备明确定义的指令:算法的每一步都必须准确定义,在任何场景下指令都应当没有歧义。3 它必须是有效的:一个算法被设计用以解决某个问题,那么它就应当能解决这个问题,并且应该是收敛的。算法设计的要求正确性:算法的正确性是指算法至少应该具有输入、输出和加工处理无歧义性、能够正确反映问题的需求、能够得到问题的正确答案1 算法程序没有语法错误2 算法程序对于合法的输入数据能够产生满足要求的输出结果3 算法程序对于非法的输入能够得出满足规格说明的结果4 算法程序对于精心选择的,甚至刁难的测试数据都能够有满足要求的输出结果
6、。可读性:算法设计的另一目的是为了便于阅读、理解和交流。健壮性:当输入数据不合法时,算法也能做出相关处理,而不是产生异常或莫名其妙的结果。时间效率与空间效率算法效率的度量方法事后统计方法:主要是通过设计好的测试程序和数据,利用计算机计时器对不同算法编制的程序的运行时间进行比较,从而确定算法效率的高低。事前分析估计方法:在计算机程序编制前,依据统计方法进行估算高级程序语言程序运行消耗时间取决于:1 算法的策略,方法。2 编译产生的代码质量3 问题的输入规模4 机器执行指令的速度可以忽略加法常数与最高项相乘的常数并不重要判断一个算法的效率时,函数中的常数和其他次要项常常可以忽略,而更应该关注最高阶
7、项的阶数时间复杂度在进行算法分析时,语句总的执行次数T(n)是关于问题规模n的函数,进而分析T(n)随n的变化情况并确定T(n)的数量级。算法的时间复杂度,也就是算法的时间度量,记作:T(n)=O(f(n)它表示随问题规模n的增大,算法执行时间的增长率和f(n)的增长率相同,称作算法的监禁时间复杂度,简称为时间复杂度。其中,f(n)是问题规模n的某个函数。推导大推导大O阶:阶:1.用用常数常数1取代运行时间中的所有加法常数。取代运行时间中的所有加法常数。2.在修改后在修改后的运行次数函数中,只保留最高阶项。的运行次数函数中,只保留最高阶项。3.如果最高阶项存在且不是如果最高阶项存在且不是1,则
8、去除与这个项相乘的,则去除与这个项相乘的常数。常数。得到得到的结果就是大的结果就是大O阶。阶。30 线性表的类型定义(a1,a2,ai-1,ai,ai1,,an)1.线性表的定义:是n个数据元素的有限序列n=0时称为数据元素线性起点ai的直接前趋ai的直接后继下标,是元素的序号,表示元素在表中的位置n为元素总个数,即表长空表线性终点31 线性表的顺序表示和实现线性表的顺序表示又称为顺序存储结构或顺序映像逻辑上相邻,物理上也相邻用一组地址连续的存储单元依次存储线性表的元素,可通过数组来实现若已知表中首元素在存储器中的位置,则其他元素存放位置亦可求出(利用数组下标)32 线性表线性表(a1,a1,
9、a2,.an)(a1,a1,a2,.an)顺序存储结构的一般形式顺序存储结构的一般形式 序号序号 存储状态存储状态 存储地址存储地址 1 b 1 b 2 b+p 2 b+p i b+(i-1)*p i b+(i-1)*p n b+(n-1)*p n b+(n-1)*p 自由区自由区 maxleng b+(maxleng-1)*p maxleng b+(maxleng-1)*p其中其中:b-:b-表的首地址表的首地址/基地址基地址/元素元素a1a1的地址。的地址。p-1 p-1个数据元素所占存储单元的数目。个数据元素所占存储单元的数目。maxleng-maxleng-最大长度最大长度,为某个常数
10、。为某个常数。a1a1 a2a2 .aiai .anan /33线性表顺序结构在C语言中的定义 其中:SqList-结构类型名 La-结构类型变量名 La.length-表长 La.elem0-a1 La.elemLa.length-1-an#define maxleng 100 struct SqList ElemType elemmaxleng;/下标:0,1,.,maxleng-1 int length;/表长;SqList La;34线性表的顺序存储结构定义(动态)#define List_Init_size 100#define Listincrement 10struct SqLi
11、st ElemType*elem;int length;int listsize;35 顺序存储结构的顺序存储结构的寻址公式寻址公式 i=1 2 i ni=1 2 i n 地址地址=b b+1 b+(i-1)p b+(n-1)p=b b+1 b+(i-1)p b+(n-1)p 假设假设:线性表的首地址为线性表的首地址为b,b,每个数据元素占每个数据元素占p p个存储个存储 单元单元,则表中任意元素则表中任意元素ai(1in)ai(1in)的存储地址是的存储地址是:LOC(i)=LOC(1)+(i-1)*p LOC(i)=LOC(1)+(i-1)*p =b+(i-1)*p (1in)=b+(i-
12、1)*p (1in)例例:假设假设 b=1024,p=4,i=35 b=1024,p=4,i=35 LOC(i)=b+(i-1)*p LOC(i)=b+(i-1)*p =1024+(35-1)*4 =1024+(35-1)*4 =1024+34*4 =1024+34*4 =1160 =1160 a1a1a2a2.aiai.anan/36插入算法实现举例设 L.elem0.maxleng-1中有legth个元素,在 L.elemi-1之插入新元素e,1=inext =first;first=newnode;(插入前)(插入后)newnodenewnodefirst firstdatanextqd
13、atanextdatanextdatanull firstdatanextdatanextdatanull firstdatanextq48在链表中间插入newnode-next=current-next;current-next=newnode;(插入前)(插入后)newnodecurrentnewnodecurrent49datanextdatanextdatanull datanextqpdatanextdatanextdatanull datanextq50在链表末尾插入newnode-next =current-next;current-next =newnode;(插入前)(插入后
14、)newnodenewnodecurrentcurrent51在链表中设置头结点在链表的首元结点之前附设的一个头结点,该结点的数据域中不存储线性表的数据元素,其作用是为了对链表进行操作时,可以对空表、非空表的情况以及对首元结点进行统一处理,编程更方便无头结点时,当头指针的值为空时表示空表;有头结点时,当头结点的指针域为空时表示空表52 循环链表(Circular List)循环链表是单链表的变形。循环链表最后一个结点的 next 指针不 为NULL,而是指向了表的前端。为简化操作,在循环链表中往往加入表头结点。循环链表的特点是:只要知道表中某一结点的地址,就可搜寻到所有其他结点的地址53循环链
15、表的示例带表头结点的循环链表a1a2a3anfirstanfirsta2a1first(空表)(非空表)54循环链表的运算与单链表类似,只是在涉及到链头与链尾的处理时稍有不同表尾插入树的基本概念树的基本概念二叉树二叉树二叉树的存储表示二叉树的存储表示二叉树的遍历二叉树的遍历1.1 树的定义和术语树的定义和术语树:树:n(n0)个个结点结点的有限的有限集合集合。当。当n0时,称为时,称为空树;任意一棵非空树满足以下条件:空树;任意一棵非空树满足以下条件:有且仅有一个特定的称为有且仅有一个特定的称为根根的结点;的结点;当当n1时时,除除根根结结点点之之外外的的其其余余结结点点被被分分成成m(m0)
16、个个互互不不相相交交的的有有限限集集合合T1,T2,Tm,其其中每个集合又是一棵树,并称为这个根结点的中每个集合又是一棵树,并称为这个根结点的子树子树。1 树的基本概念树的基本概念树的定义是采用递归方法树的定义是采用递归方法(a)一棵树结构一棵树结构 (b)一个非树结构一个非树结构 (c)一个非树结构一个非树结构 ACBGFEDHIACBGFDACBGFDE以下哪一棵是树?哪一棵不是?理由?结点的度:结点的度:结点所拥有的子树的个数。结点所拥有的子树的个数。树的度:树的度:树中各结点度的最大值。树中各结点度的最大值。CGBDEFKLHMIJA叶子结点:叶子结点:度为度为0的结点,也称为终端结点
17、。的结点,也称为终端结点。分支结点:分支结点:度不为度不为0的结点,也称为非终端结点。的结点,也称为非终端结点。CGBDEFKLHMIJA孩子、双亲:孩子、双亲:树中某结点子树的根结点称为这个结点树中某结点子树的根结点称为这个结点的的孩子结点孩子结点,这个结点称为它孩子结点的,这个结点称为它孩子结点的双亲结点双亲结点;兄弟:兄弟:具有同一个双亲的孩子结点互称为兄弟。具有同一个双亲的孩子结点互称为兄弟。CGBDEFKLHMIJA路径:路径:如果树的结点序列如果树的结点序列n1,n2,nk有如下关系:结有如下关系:结点点ni是是ni+1的双亲(的双亲(1=ik),则把,则把n1,n2,nk称为称为
18、一条由一条由n1至至nk的路径;路径上经过的边的个数称为的路径;路径上经过的边的个数称为路路径长度径长度。CGBDEFKLHMIJA祖先、子孙:祖先、子孙:在树中,如果有一条路径从结点在树中,如果有一条路径从结点x到结到结点点y,那么那么x就称为就称为y的祖先,而的祖先,而y称为称为x的子孙。的子孙。CGBDEFKLHMIJA结点所在层数:结点所在层数:根结点的层数为根结点的层数为1 1;对其余任何结点,;对其余任何结点,若某结点在第若某结点在第k k层,则其孩子结点在第层,则其孩子结点在第k+1k+1层。层。树的深度:树的深度:树中所有结点的最大层数,也称树中所有结点的最大层数,也称高度高度
19、。1 1层层2层层4 4层层3层层高度高度4CGBDEFKLHMIJCCBDEFKLHJA71234568910层序编号:层序编号:将树中结点按照从上层到下层、同层从左将树中结点按照从上层到下层、同层从左到右的次序依次给他们编以从到右的次序依次给他们编以从1 1开始的连续自然数。开始的连续自然数。有序树、无序树:有序树、无序树:如果一棵树中结点的各子树从左如果一棵树中结点的各子树从左到右是有次序的,称这棵树为有序树;反之,称为到右是有次序的,称这棵树为有序树;反之,称为无序树。无序树。数据结构中讨论的一般都是有序树数据结构中讨论的一般都是有序树 ACBGFEDACBGFED树结构和线性结构的比
20、较树结构和线性结构的比较线性结构线性结构线性结构线性结构树结构树结构树结构树结构第第一一个数据元素个数据元素根结点(只有根结点(只有一一个)个)无前驱无前驱无双亲无双亲最后最后一一个数据元素个数据元素叶子结点叶子结点(可以有可以有多多个个)无后继无后继无孩子无孩子其它数据元素其它数据元素其它结点其它结点一个前驱一个前驱,一个后一个后继继一个双亲一个双亲,多个孩子多个孩子一对一一对一一对一一对一 一对多一对多一对多一对多二叉树的定义二叉树的定义二叉树的定义二叉树的定义 二叉树是二叉树是n(n0)个结点的有限集合,该集合或个结点的有限集合,该集合或者为空集(称为空二叉树),者为空集(称为空二叉树)
21、,或者由一个根结点或者由一个根结点和两棵和两棵互不相交互不相交的、分别称为根结点的的、分别称为根结点的左子树左子树和和右子树右子树的二叉树组成。的二叉树组成。2 二叉树二叉树问题转化:将树转换为二叉树,从而利用二叉树解问题转化:将树转换为二叉树,从而利用二叉树解问题转化:将树转换为二叉树,从而利用二叉树解问题转化:将树转换为二叉树,从而利用二叉树解决树的有关问题。决树的有关问题。决树的有关问题。决树的有关问题。研究二叉树的意义?研究二叉树的意义?2.1 2.1 2.1 2.1 二叉树的定义二叉树的定义二叉树的定义二叉树的定义 二叉树的特点:二叉树的特点:每个结点最多有两棵子树;每个结点最多有两
22、棵子树;二叉树是有序的,其次序不二叉树是有序的,其次序不能任意颠倒能任意颠倒。注意:二叉树和树是两种树结构。注意:二叉树和树是两种树结构。ABCDEFGABAB二叉树的基本形态二叉树的基本形态空二叉树空二叉树只有一个根结点只有一个根结点左子树左子树根结点只有左子树根结点只有左子树右子树右子树根结点只有右子树根结点只有右子树左子树左子树右子树右子树根结点同时有左右子树根结点同时有左右子树具有具有3 3个结点的树和具有个结点的树和具有3 3个结点的二叉树的形态个结点的二叉树的形态v二叉树和树是两种树结构。二叉树和树是两种树结构。2.2 2.2 2.2 2.2 二叉树的性质二叉树的性质二叉树的性质二
23、叉树的性质 性质性质1 二叉树的第二叉树的第i层上最多有层上最多有2i-1个结点(个结点(i1)。)。证明:证明:当当i=1时时,第,第1层只有一个根结点,而层只有一个根结点,而 2i-1=20=1,结论显然成立。结论显然成立。假定假定i=k(1ki)时结论成立,即第)时结论成立,即第k层上至多有层上至多有2k-1个结点,个结点,则则 i=k+1时时,因为第,因为第k+1层上的结点是第层上的结点是第k层上结点的孩子,而二叉树中每个结点最多有层上结点的孩子,而二叉树中每个结点最多有2个个孩子,故在第孩子,故在第k+1层上最大结点个数为第层上最大结点个数为第k层上的最层上的最大结点个数的二倍,即大
24、结点个数的二倍,即22k-12k。结论成立。结论成立。证明用数学归纳法证明用数学归纳法性质性质2 深度为深度为k(k0)的二叉树,最多有的二叉树,最多有2k-1个结点,个结点,最少有最少有k个结点。个结点。证明:由性质证明:由性质1可知,深度为可知,深度为k的二叉树中结点个数最多的二叉树中结点个数最多=2k-1;每一层至少要有一个结点,因此深度为每一层至少要有一个结点,因此深度为k的二叉树,的二叉树,至少有至少有k个结点。个结点。深度为深度为k且具有且具有2k-1个结点的二叉树个结点的二叉树一定是一定是满二叉树,满二叉树,性质性质3 对任何一棵非空二叉树对任何一棵非空二叉树,如果如果叶子结点叶
25、子结点数为数为n0,度为度为2的结点数为的结点数为n2,则有则有:n0n21。证明:证明:设度为设度为1的结点数为的结点数为n1,二叉树总的结点数二叉树总的结点数为为n,则有则有:n=n0 n1 n2。再设分支条数为再设分支条数为e,有有e=n-1=n0 n1 n2 1,同时有同时有 e=n1 2n2 因此得因此得 n0 n1 n2 1=n1 2n2,于是得证。于是得证。性质性质4 具有具有n个结点的完全二叉树的最小深度为个结点的完全二叉树的最小深度为 log2(n+1)。证证明明:假假设设具具有有n个个结结点点的的完完全全二二叉叉树树的的深深度度为为k,根据完全二叉树的定义和性质根据完全二叉
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 算法 课件
限制150内