探究如何提升计算机的算法效率

探究如何提升计算机的算法效率

ID:35505813

大小:56.25 KB

页数:4页

时间:2019-03-25

探究如何提升计算机的算法效率_第1页
探究如何提升计算机的算法效率_第2页
探究如何提升计算机的算法效率_第3页
探究如何提升计算机的算法效率_第4页
资源描述:

《探究如何提升计算机的算法效率》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、探究如何提升计算机的算法效率探究如何提升计算机的算法效率【摘要】算法效率的高低直接决定一个算法的好坏,解决一个实际问题可以设计出很多的算法,但是其效率是不一样的,如在数组中查找一个元素,既可以一个元素一个元素的遍历,也可以对半查找,显然对半查找比遍历快得多,也就是说对半查找的效率要高。设计高效率的算法一直是计算机科学领域学者孜孜不倦的追求,本文将从实际问题入手,探究影响算法执行效率的因素,从而提出优化措施,总结优化经验,进而为日后设计高效率的算法奠定坚实的理论与实践基础。【关键词】算法,效率,优化算法效率通常使用算法的时间复杂度

2、和空间复杂度来衡量,时间复杂度和空间复杂度又可以统称为时空复杂度。算法的时间复杂度关心算法关键部分代码的执行次数,如遍历一个长度为N的数组,那么关键代码需要执行N次,时间复杂度就为;算法的空间复杂度则主要关心算法运行时所需占用的存储空间。显然,一个好的算法其时间复杂度和空间复杂度都比较小。一、影响算法效率的因素影响算法效率的因素有很多,如问题的规模,显然问题规模越大算法执行时间越长;实现算法的编程语言也会影响算法效率,选择编译型语言要比解释型语言效率高,如选择使用C语言就要比选择使用Java语言实现算法效率高;数据结构的选择,设

3、计合理的数据结构可以方便操作,减少空间占用;编译产生机器代码的质量,很多编译器会在产生机器代码时进行优化,从而提高算法效率;机器执行指令的速度,机器执行一条指令的速度越快那么算法的效率就越高。上述影响算法效率的因素,有的可以通过更加巧妙的算法设计来规避冗余运算来提高效率,有的可以通过多核心并行来提高处理速度从而提高效率,接下来我们就探讨算法中提高效率的设计艺术。二、提升算法效率的策略(一)递归转换为非递归实现递归是一种常用的程序编写方式,它可以把一个大的复杂的问题转化为较小的相似的问题进行求解。然而,递归是通常过程或函数自己调用

4、自己来实现的,它并不是一种高效的算法编写方式,在调用过程中系统需要处理断点,保存中断向量等,并且这些操作所以消耗的指令时间也远大于其他的指令开销。因此,实现算法时应当尽量将递归部分代码转换为非递归的方式实现。例如,计算N的阶乘,其递归算法可如下方式:1intF(intn)2{3if(n=l

5、

6、n=0)4return1;5else6returnn*F(n-1);7}函数中的笫六行代码调用函数自身,实现递归。使用非递归算法改写程序如下:intF(intn){if(n=0)reurn1;intx二1;for(i=l;i〈二n;i++)

7、x二x*i;returnx;}改写后的程序中取消了函数调用自身的代码,冃的是为了减少因系统维护中断程序所需要花费的开销。此例只是一个简单的示例,通常,将递归算法改写为非递归算法时,需要用到栈来保存未完成的工作,需要时再将数据从栈中取出,在进行转换时,对递归函数的实现过程进行公式递推就可得出其非递归实现。(二)设计合理的数据结构合理的数据结构对算法的性能至关重要,一个合理的数据结构可以使用算法中对变量的访问更加便捷,同时也能减少变量所需的内存空间,从而提高算法的效率。例如,对于稀疏矩阵,如果矩阵中元素较多,那么就应该考虑压缩矩阵的

8、存储空间,如果直接定义二维数组来存储矩阵,由于稀疏矩阵中存在大量零元素,那么势必会浪费大量的存储空间,此时可以考虑使用三元组(行号,列号,元素值)来存储稀疏矩阵,这样一来就能极大地压缩稀疏矩阵所占用的内存空间,同时遍历矩阵时也可以减少遍历次数,从而提高算法效率。此外,对于共享变量,通常可以使用联合体的方式,使多个变量共享同一段内存空间,这是通过降低算法的空间复杂度来提高算法效率的一种方法。(三)通过并行计算降低算法执行时间通过并行计算大幅降低算法执行时间有两种方式,一是在单机上多核心之间的并行;二是多机间的并行。目前,计算机硬件

9、设备更新较快,主流计算机大多是双核心甚至是四核心,同时,计算机软件发展迅速,分布式系统日渐流行。然而,大多数的算法并没有针对多核心计算机或是分布式系统进行优化,依然是串行执行。通过对算法进行分析,将算法分为可并行部分和不可并行部分(即串行部分),将可并行部分分配给同一机器上不同的核心并行运行,或是将可并行部分分配给分布式系统中不同的主机运行,然后将结果汇总。在分布式系统进行并行计算时需要权衡算法的运算量和网络开销,从而作出一个合理的分配。并行计算的方式并没有降低算法的时间复杂度,而是通过并行执行的方式减少了算法运行所需的时间,充

10、分利用多核心计算机的硬件优势或是分布是系统的结构优势来提高算法的效率。(四)借鉴已有的高效算法冃前已经存在大量公认的高效率的算法,我们在设计自己的算法时,可以充分借鉴这类算法来提高自己算法的效率。例如自己的算法中需要进行查找操作,这时就可以直接调用快速排序或堆排

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。