算法分析的目的是什么

如题所述

回答如下:

目的是评价算法的效率,通过评价可以选用更加好更加适合的算法来完成。

算法分析

算法分析是对一个算法需要多少计算时间和存储空间作定量的分析。 算法(Algorithm)是解题的步骤,可以把算法定义成解一确定类问题的任意一种特殊的方法。在计算机科学中,算法要用计算机算法语言描述,算法代表用计算机解一类问题的精确、有效的方法。

中文名

算法分析

外文名

Algorithm analysis

应用

算法优化

网络应用

引擎的算法应用

主要对象

时间复杂度、空间复杂度

作用

评价算法的好坏

简介

算法是一组有穷的规则,它们规定了解决某一特定类型问题的一系列运算,是对解题方案内的准确与完整地描述。制定一个算法,一般要经过设计、确认、分析、编码、测试、调试、计时等阶段。[1]

算法+数据结构=程序,求解一个给定的可计算或可解的问题,不同的人可以编写出不同的程序,来解决同一个问题,这里存在两个问题:一是与计算方法密切相关的算法问题;二是程序设计的技术问题。算法和程序之间存在密切的关系。分析算法可以预测这一算法适合在什么样的环境中有效地运行,对解决同一问题的不同算法的有效性作出比较。[1]

通常对于一个实际问题的解决,可以提出若干个算法,如何从这些可行的算法中找出最有效的算法呢?或者有了一个解决实际问题的算法后,如何来评价它的好坏呢?这些问题都需要通过算法分析来确定。评价算法分析性能的标准主要从算法执行时间和占用存储空间两个方面进行考虑,即通过分析算法执行所需要的时间和存储空间来判断一个算法的优劣。[2]

时间复杂度

一个程序的时间复杂度是指程序运行从开始到结束所需要的时间。

影响因素

一个算法是由控制结构(顺序、分支和循环3种)和原操作(指固定数据类型的操作)构成的,其执行时间取决于两者的综合效果。为了便于比较同一问题的不同算法,通常的做法是:从算法中选取一种对于所研究的问题来说基本运算的原操作,以该原操作重复执行的次数作为算法的时间度量。一般情况下,算法中原操作重复执行次数是规模n的某个函数T(n)。许多时候要精确的计算T(n)是困难的,引入渐进时间复杂度在数量上估计一个算法的执行时间,也能够达到分析算法的目的。[3]

计算方法

计算时间复杂度的时候,主要考虑算法中最高阶项的开销,只要找出算法中最高阶的复杂度,就可以忽略低阶和常数的复杂度。[3]

引入数学符号“O”来估算算法时间复杂度,渐进时间复杂度的表示方法:F(n)=O(g(n)),其定义为,若F(n)和g(n)是定义在正整数集合上的两个函数,则F(n)=O(g(n))表示存在正的常数C和  ,使得当  时,都满足  。换句话说,就是这两个函数当整形自变量n趋于无穷大时,两者的比值是一个不等于0的常数。[3]

当要计算某个算法的时间复杂度F(n)时,可以找一个更简单的、阶数相同的简单算法g(n)等同计算,这里的g(n)是指替代函数,它具有和原算法一样更高阶复杂度。[3]

例如,一个程序的实际执行时间为:  ,则  。使用O记号表示的算法的时间复杂度,称为算法的渐进时间复杂度。[3]

常见的渐进时间复杂度

通常用O(1)表示常数计算时间。常见的渐进时间复杂度有:

规则

为了便于估算一个算法的时间复杂度,我们约定一下几条可操作的规则:

(1)读写单个常量或单个变量、赋值、算术运算、关系运算、逻辑运算等,计为一个单位时间。

(2)条件语句if(C){s},执行时间为(条件C的执行时间)+(语句块s的执行时间)。

(3)条件语句if(C)s1 else s2,执行时间为(条件C的执行时间)+(语句块s1和s2中执行时间最长的那个时间)。

(4)switch...case语句的执行时间是所有case子句中,执行时间最长的语句块。

(5)访问一个数据的单个元素或一个结构体变量的单个元素只需要一个单位时间。

(6)执行一个for循环语句需要的时间等于执行该循环体所需要时间乘上循环次数。

(7)执行一个while(C){s}循环语句或者执行一个do{s} while(C)语句,需要的时间等于计算条件表达式C的时间与执行循环s的时间之和再乘以循环的次数。

(8)对于嵌套结构,算法的时间复杂度由嵌套最深层语句的执行次数决定的。

(9)对于函数调用语句,它们需要的时间包括两部分,一部分用于实现控制转移,另一部分用于执行函数本身。[3]

温馨提示:内容为网友见解,仅供参考
无其他回答

算法分析的目的是()
正确答案:分析算法的效率以求改进

算法分析的目的是( )。 A.找出数据结构的合理性B.找出算法中输入和输...
D.【解析】算法是指对解题方案准确而完整的描述。对算法进行分析是为了在原有的基础上,对算法进行改进,从而提高对数据的处理效率。

算法分析的目的是( )。 A.找出算法的输入输出之间的关系 B.找出数据结...
答案D

算法分析的目的是( )。A.找出数据结构的合理性B.找出算法中输入和输出之...
算法分析是指对一个算法的运行时间和占用空间做定量的分析,计算相应的数量级,并用时间复杂度和空间复杂度表示。分析算法的目的就是要降低算法的时间复杂度和空间复杂度,提高算法的执行效率。

算法分析的目的是( )。 A.找出算法的输入输出之间的关系 B.找出数据结...
C

算法分析的目的是
分析算法的效率以求改进。根据查询百度题库得知,算法分析的目的是___?。A.找出数据结构的合理性;B.找出算法中输入和输出之间的关系;C.分析算法的易懂性和可靠性;D.分析算法的效率以求改进。答案:D。算法分析是对一个算法需要多少计算时间和存储空间作定量的分析。算法(Algorithm)是解题的步...

算法分析的主要目的是什么?
1. 算法分析的主要目的是对算法的效率进行定量分析,以便改进算法。2. 根据百度题库的查询结果,算法分析的目的在于分析算法的效率以求改进,答案为D。3. 算法分析涉及对数据结构的合理性、算法中输入和输出之间的关系、算法的易懂性和可靠性的分析,但其核心目的是评估算法的效率,并据此进行优化。4. ...

算法分析的目的是什么?
目的是评价算法的效率,通过评价可以选用更加好更加适合的算法来完成。算法分析是对一个算法需要多少计算时间和存储空间作定量的分析,算法是解题的步骤,可以把算法定义成解一确定类问题的任意一种特殊的方法。在计算机科学中,算法要用计算机算法语言描述,算法代表用计算机解一类问题的精确、有效的方法。从...

算法分析的目的是( )
算法分析的目的是分析算法效率以求改进。算法分析是对一个算法需要多少计算时间和存储空间作定量的分析。 算法(Algorithm)是解题的步骤,可以把算法定义成解一确定类问题的任意一种特殊的方法。在计算机科学中,算法要用计算机算法语言描述,算法代表用计算机解一类问题的精确、有效的方法。算法+数据结构=...

为什么要对算法进行分析?
同一问题可用不同算法解决,而一个算法的质量优劣将影响到算法乃至程序的效率。算法分析的目的在于选择合适算法和改进算法。一个算法的评价主要从时间复杂度和空间复杂度来考虑。时间复杂度 算法的时间复杂度是指执行算法所需要的计算工作量。一般来说,计算机算法是问题规模n 的函数f(n),算法的时间复杂度...

相似回答
大家正在搜