- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构讲义第1章
第*页2010-9-1 (3)有如下递归函数fact(n),分析其时间复杂度fact(int n) fact(int n) { if(n=1) return (1); (1) else return( n*fact(n-1)); (2) } 分析: 设fact(n)的运行时间函数是T(n),该函数中语句(1) 的运行时间是O(1),语句(2) 的运行时间是T(n-1)+O(1),其中O(1)为运算的时间。 因此 O(1) n=1 T(n)= T(n-1)+O(1) n1 第*页2010-9-1 则T(n)=O(1)+T(n-1) =2*O(1)+T(n-2) =…… =(n-1)*O(1)+T(1) =n*O(1) =O(n) 即T(n)=O(n) 第*页2010-9-1 本课程涉及的主要结构 线性表:线性表是一种逻辑上十分简单但应用非常广泛的数据结构,线性表中各元素之间是一种简单的“线性”关系。顺序表和链表是两种常用的实现线性表的数据结构,它们也是许多复杂结构的基本表示形式。 堆栈与队列:堆栈和队列是两种十分重要的数据结构。堆栈元素的存入和取出按照后进先出原则,最先取出的总是在此之前最后放进去的那个元素;而队列实现先进先出的原则,最先到达的元素也最先离开队列。 字符串:字符串也是一种特殊的线性结构,它以字符为元素。 第*页2010-9-1 树与二叉树:树和二叉树都属“树形结构”,在逻辑上表示了结点的层次关系,是一种非线性结构。树最上面一层只有一个元素,称为“树根”。每个元素可以有若干相关联的下层元素,这些元素被称为是该上层元素的“子结点”;每个下层元素至多有一个对应的上层元素,称为它的“父结点”。许多实际的和理论的问题中都可以抽象出某种树形结构来。 图:图是一种较复杂的结构,它包括一个结点集合和一个边集合,边集合中每条边联系着两个结点。信息可以存储在结点里,也可以存储在边里。许多实际问题中的数据可以用图表示,如公路网络、通信网络、不同事物间的联系,等等。 第*页2010-9-1 (1)分析其中order()函数的时间复杂度 int a[]={2,5,1,7,9,3,6,8}; order(int j,int m) { int I,temp; if(jm) { for(I=j;i=m;I++) if(a[I]a[j]) { temp=a[I]; a[I]=a[j]; a[j]=temp; } j++; order(j,m); } } Main() { int I; order(0,7); for(I=0;I=7;I++) printf(“%d”,a[I]); } 作业: (2)分析该程序段的时间复杂度 a=0;b=1; (1) for(I=2;I=n;I++) (2) { s=a+b; (3) b=a; (4) a=s; (5) } 第*页2010-9-1 作业答案: (1)分析:order()函数是一个递归排序过程,设T(n)(n=m+1)是排序n个元素的所需要的时间,在排序n个元素时,算法的计算时间主要花费在递归调用order()上。第一次调用时,处理的元素个数为n-1,也就是对余下的n-1个元素进行排序,这部分所需要的计算时间为T(n-1)
文档评论(0)