程序优化降低复杂度_第1页
程序优化降低复杂度_第2页
程序优化降低复杂度_第3页
全文预览已结束

下载本文档

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

文档简介

1、32程序优化-降-低复杂度时间昂贵、空间廉价一段代码会消耗计算时间、资源空间,从而产生时间复杂度和空间复杂度。假设一段代码经过优化后,虽然降低了时间复杂度,但依然需要消耗非常高的空间复杂度。0例如,对于固定数据量的输入,这段代码需要消耗几十G的内存空间,很显然普通计算机根本无法完成这样的计算。如果一定要解决的话,一个最简单粗暴的办法就是,购买大量的高性能计算机,来弥补空间性能的不足。反过来,假设一段代码经过优化后,依然需要消耗非常高的时间复杂度。例如,对于固定数据量的输入,这段代码需要消耗10年的时间去完成计算。如果在跑程序的010年时间内,出现了断电、断网或者程序抛出异常等预期范围之外的问题

2、,那很可能造成10年时间浪费的惨重后果。很显然,用皿年的时间去跑一段代码,对开发者和运维者而言都是极不友好的。这告诉我们一个什么样的现实问题呢?代码效率的瓶颈可能发生在时间或者空间两个方面。如果是缺少计算空间,花钱买服务器就可以了。这是个花钱就能解决的问题。相反,如果是缺少计算时间,只能投入宝贵的人生去跑程序。即使你有再多的钱、再多的服务器,也是毫无用处。相比于空间复杂度,时间复杂度的降低就显得更加重要了。因此,你会发现这样的结论:空间是廉价的,而时间是昂贵的。程序优化的最核心的思路第一步,暴力解法。在没有任何时间、空间约束下,完成代码任务的开发。第二步,无效操作处理。将代码中的无效计算、无效

3、存储剔除,降低时间或空间复杂度案例一体现)。第三步,时空转换。设计合理数据结构,完成时间复杂度向空间复杂度的转移案例二体现)。说明:常用的降低时间复杂度的方法有递归、二分法、排序算法、动态规划等,而降低空间复杂度的方法就是数据结构,核心思路就是,能用低复杂度的数据结构能解决问题,就千万不要用高复杂度的数据结构。1/*0200*oauthor0佛大Java程序员*since1.0.0*/publicclassAlgorithmTest4publicstaticvoidmain(Stringargs)AlgorithmTest4algorithmTest4=newAlgorithmTest4();

4、algorithmTest4.s2_1();TOC o 1-5 h zSystem.out.println();algorithmTest4.s2_2();12/*000000*方法一0:时间复杂度为o(0n皿*/publicvoids2_1()intcount=0;for(inti=0;i(100/7);i+)for(intj=0;j(100/3);j+)for(intk=0;k=(100/2);k+)if(i*7+j*3+k*2=100)count+=1;/System.out.println(i:+i+j:+j+k:+k);TOC o 1-5 h zSystem.out.println(

5、方法一总共:+count+组合);3031/*32333435363738394041424344454647运行结果案例二查找出一个数组中,出现次数最多的那个元素的数值。*方法二:时间复杂度为0(n*/publicvoids2_2()intcount=0;for(inti=0;i(100/7);i+)for(intj=0;j=0)count+=1;/System.out.println(i:+i+j:+j);System.out.println(方法二总共:+count+组合);方法一:使用3层的for循环。从结构上来看,是很显然的0(山)的时间复杂度。然而,仔细观察就会发现,代码中最内层的

6、for循环是多余的。因为,当你确定了要用i张7元和j张3元时,只需要判断用有限个2元能否凑出100-7*i-3*j元就可以了。方法二:代码的结构由3层for循环,变成了2层for循环。很显然,时间复杂度就变成了0(2)。这样的代码改造,就是利用了方法论中的步骤二,将代码中的无效计算、无效存储剔除,降低时间或空间复杂度。3232System.out.println(方法一,次数最多的那个元素的数值:+maxVal);例如,输入数组a=1,2,3,4,5,5,6中,查找出现次数最多的数值。从数组中可以看出,只有5出现了2次,其余都是1次。显然5出现的次数最多,则输出5。1/*author佛大Jav

7、a程序员*since1.0.0*/publicclassAlgorithmTest567891011121314151617181920212223242526272829303132publicstaticvoidmain(Stringargs)AlgorithmTest5algorithmTest5=newAlgorithmTest5();algorithmTest5.s2_3();algorithmTest5.s2_4();/*方法一:时间复杂度就是0(n*/publicvoids2_3()inta=1,2,3,4,5,5,6;/初始化最大值,最大次数,临时记录次数intmaxVal=0

8、,maxTime=0,tmpTime;for(inti=0;ia.length;i+)tmpTime=0;for(intj=0;jmaxTime)maxTime=tmpTime;maxVal=ai;3233/*rnrnn方法二:时间复杂度为ao(n)*/publicvoids2_4()inta=1,2,3,4,5,5,6;Mapd=newHashMap();for(inti=0;imaxTime)maxTime=d.get(key);maxVal=key;TOC o 1-5 h zSystem.out.println(方法二,次数最多的那个元素的数值:+maxVal);方法一:采用两层的fOB

9、循环完成计算。第一层循环,对数组每个元素遍历。第二层循环,则是对第一层遍历的数字,去遍历计算其出现的次数。这样,全局再同时缓存一个出现次数最多的元素及其次数就可以了时间复杂度就是亚nm。而且代码中,几乎没有冗余的无效计算。如果还需要再去优化,就要考虑采用一些数据结构方面的手段,来把时间复杂度转移到空间复杂度乙方法二:定义一个Dk-va结构的字典,用来存放元素出现次数的Dk-VD关系。那么首先通过一次循环,将数组转变为元素出现次数的一个字典。接下来,再去遍历一遍这个字典,找到出现次数最多的那个元素,就能找到最后的结果了。代码结构上,有两个fOB循环。不过,这两个循环不是嵌套关系,而是顺序执行关系。其中,第一个循环实现了数组转字典的过程,也就是0(n)D的复杂度。第二个循环再次遍历字典找到出现次数最多的那个元素,也是一个ao(n)D的时间复杂度。因此,总体的时间复杂度为ao(n)D+ao(n),就是ao(2

温馨提示

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

评论

0/150

提交评论