- 1、本文档共16页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
5.1数据结构与算法效率
一个人想要喝茶,但当时的情况是:开水没有,水壶要洗,茶壶和茶杯要洗;火已经生了,茶叶也有了怎么办?泡茶甲:洗开水壶灌凉水洗茶壶洗茶杯拿茶叶泡茶喝烧开水乙:洗开水壶洗茶壶洗茶杯拿茶叶灌凉水烧开水泡茶喝丙:洗开水壶灌凉水烧开水拿茶叶洗茶壶洗茶杯泡茶喝
在计算机科学中,数据结构与算法有着密不可分的关系。解决实际问题时,数据总是以一定的组织结构关系体现并存储,数据结构的设计和选择关注的是数据的逻辑结构、存储结构以及基本操作;算法的设计和选择更多的是关注如何在数据结构的基础上综合运用各种基本数据操作来解决实际问题。因此,算法的设计和选择总是依赖于数据结构,算法设计的同时也伴随着数据结构的设计,两者都是为最终解决问题服务。同时,数据结构的设计和选择会对算法效率产生一定的影响。
算法效率同一个问题可能会有不同的解决方法,也就是说可能有不同的算法。有的算法效率高一些,有的算法效率低一些。通常,算法效率的高低可由算法复杂度来度量。算法复杂度又分为算法的时间复杂度和空间复杂度,其中时间复杂度反映了算法执行所需要的时间,而空间复杂度反映了算法执行所需要占用的存储空间。
算法运行需要的时间,一般将算法中语句的执行次数作为时间复杂度的度量标准。语句总的执行次数T(n)是关于问题规模n的函数。所谓问题规模(也称为输入的大小)是指处理问题的大小,即用来衡量输入数据量的整数。12345678910………n在约瑟夫问题中,用数组或链表中元素的个数作为问题规模。
?用O()来体现算法时间复杂度,称之为大O记法。
通常,随着问题规模n的增大,函数值增长较慢的算法较优。例如,求1+2+…+n的和可以用以下两种算法来实现:算法一:n=int(input())#执行1次s=(1+n)*n/2#执行1次print(s)#执行1次算法二:n=int(input())#执行1次s=0#执行1次foriinrange(1,n+1):#执行n次s=s+i#执行n次print(s)#执行1次时间复杂度为O(1),常量阶时间复杂度为O(n)线性阶
再来看下面的例子:n=int(input())s=0x=0foriinrange(1,n+1):forjinrange(1,n+1):x=x+1#执行n*n次s=s+xprint(s)时间复杂度是O(n2),称为平方阶。
?算法的时间复杂度反映了程序执行时间随问题规模增长而增长的量级,在很大程度上能很好地反映出算法的优劣。
举例说明空间复杂度是如何度量的。程序运行过程中,一般将所占用的辅助存储空间大小作为度量算法空间复杂度的标准。一个算法在计算机存储器上占用的存储空间,主要包括程序代码占用的空间,输入或输出数据占用的空间,以及额外辅助程序运行占用的存储空间这三个方面。输入或输出数据占用的空间是必须的,程序代码占用的空间可以通过精简代码来实现,但非常有限。由于算法设计的差异,算法运行过程中的辅助空间相差较大,因此是衡量算法空间复杂度的关键因素。例如,算法中需要处理一个数据规模为n的连续整数数组,则其空间复杂度至少为O(n)。
数据结构对算法效率的影响数据组织成不同的结构,是为了满足不同问题的需求,便于算法对数据的操作,提高算法处理数据的效率。例1:要显示10000种商品中某个商品的价格在设计数据结构时,可以将这10000中商品的价格数据采用数组或链表来组织。但从算法效率的角度考虑,此时数据结构采用数组比链表更方便,这是因为数组中的元素可以按其下标方便地被随机访问,时间复杂度为O(1);而在链表中访问任何节点都必须从首节点(或尾节点)开始按序访问到指定节点,时间复杂度为O(n)。
例2:要在10000种商品中添加或删除某个商品信息算法需要对元素做插入、删除操作,那么数据结构采用链表比较合适,这是因为在数组中插入或删除一个元素都可能引起大量元素的移动操作,时间复杂度为O(n);而在链表中插入或删除一个节点只需要对个别节点的链域进行修改,时间复杂度为O(1)。因此,数据结构的不同选择会影响算法的运行效率。
练一练1.某算法的部分流程图如下:输入aa5?bAbs(a)Ya10?NYbSqr(a)/2Nba/2输出b其算法的时间复杂度是()A.常量阶B.线性阶C.指数阶D.对数阶A
2.分析如下Pyth
您可能关注的文档
- 用车申请单车辆管理单.docx
- 幼儿拼音表韵母表.docx
- 幼儿启蒙一年级汉语拼音字母笔画笔顺表(可编辑打印).docx
- 幼儿小学英语字母发音拼写练习.docx
- 幼小衔接韵母声调表.docx
- 预防疾病从正确洗手开始.docx
- 员工工作情况测评记录表.docx
- 员工过失处罚决定表.docx
- 员工劳动合同到期自评表.docx
- 员工年终考核鉴定表.docx
- 信息系统安全与防护课件浙教版(2019)高中信息技术必修2(21张PPT).ppt
- 移动终端、传感器课件高中信息技术浙教版(2019)必修2(24张PPT).ppt
- 栈课件(共21张PPT)浙教版(2019)信息技术选修1.ppt
- 浙教版高中信息技术必修一1.1信息及特征(共19张PPT).ppt
- 浙教版高中信息技术必修一2.1信息获取的方法2.2因特网上信息的浏览与获取课件(25张幻灯片).ppt
- 浙教版高中信息技术必修一4.1信息资源管理及其沿革4.2数据库系统(2课时课件,26张幻灯片).ppt
- 浙教版高中信息技术必修一4.2《数据库系统》课件(18张幻灯片).ppt
- 浙教版高中信息技术必修一6.2:网页制作课件(34张幻灯片).ppt
- 浙教版高中信息技术必修一23:网上资源检索课件(20张幻灯片).ppt
- 浙教版高中信息技术必修一4.1:信息资源管理及其沿革课件.ppt
文档评论(0)