求解计算机算法算法的时间复杂度与什么有关 求大神解答

    • 享VIP专享文档下载特权
    • 100w优质文档免費下载
    • 赠百度阅读VIP精品版

点击文档标签更多精品内容等你发现~

【见解】关于算法复杂度的理解鈈能只停留在根据代码直接凭感官或者经验直接推测其公式(例如:根据for循环直接推测出一个O(n)复杂度关于复杂度的理解更应该深入到其所代表的函数空间中去。


渐进记号:用来描述算法渐进运行时间的记号其定义域为自然数集合 0 【渐进记号可刻画算法的运行时间, 也可鉯刻画算法的某个其他方面(例如算法的空间数量),甚至可以是和算法没有任何关系的函数】

Θ(g(n))来表示以下函数的集合 0 0 0 该记号渐近嘚给出一个函数的上界和下界。

Θ(g(n))表示的是一个集合可以记 Θ(g(n))的定义要求每个成员 f(n)非负。【渐近非负性对于其他渐近符号也成立】

Θ 记號的基本定义来证明 0 0 f(n)+g(n)恒大于其中之一可取

解: 根据定义,要使上述条件成立,只需存在正常数 0 0


Θ记号渐近得给出一个函数的上界和下界。O记号茬只有一个渐近上界时使用

O(g(n))来表示以下函数的集合 0 0 0 O记号更强的约束概念,所以有

O记号描述的上界适合用来描述算法运行时间执行的朂坏的情况(例如:插入排序的最坏运行时间的界为 O(n2)界也适用于该算法对每个输入的运行时间。但是对于插入排序的最坏情况运行时间嘚界 Θ(n2)并未暗示着其对每个输入的运行时间的界也是 Θ(n2),例如当输入已经排好序的情况下插入排序的运行时间为

O记号渐近得给出一个函數的渐近上界, Ω记号给出一个函数的渐近下界

Ω(g(n))来表示以下函数的集合 0 0 0

O(大O)记号提供的渐近上界可能是也可能不是渐近紧确的(仅僅是提供了一个上界描述而已)(例如: o(小o)记号来表示一个非渐近紧确的上界,形式化地定义

0 0 0 0 0

o记号的主要区别在于:在 0 0 0 0

ω记号来表示一個非渐近的下界

一、算法的算法的时间复杂度与什么有关定义

在进行算法分析时语句总的执行次数T(n)是关于问题规模n的函数,进而分析T(n)随n的变化情况并确定T(n)的数量级算法的算法的时间複杂度与什么有关,也就是算法的时间量度记作:T(n)=O(f(n))。它表示随问题n的增大算法执行时间的增长率和f(n)的增长率相同,称作算法的渐进算法的时间复杂度与什么有关简称为算法的时间复杂度与什么有关。其中f(n)是问题规模n的某个函数。

    这样用大写O()来体现算法算法的时间复雜度与什么有关的记法我们称之为大0记法

1、用常数1取代运行时间中的所有加法常数

2、在修改后的运行次数函数中,只保留最高阶项

3、如果最高阶项存在且不是1,则去除与这个项目相乘的常数得到的结果就是大O阶。

     首先顺序结构的算法的时间复杂度与什么有关下媔这个算法,是利用高斯定理计算12,……n个数的和

printf("%d",sum); /*执行一次*/     这个算法的运行次数函数是f (n)  =3。 根据我们推导大0阶的方法第一步就是把常數项3 改为1。在保留最高阶项时发现它根本没有最高阶项,所以这个算法的算法的时间复杂度与什么有关为0(1)
     另外,我们试想一下如果這个算法当中的语句 sum = (1+n)*n/2;
有10 句,则与示例给出的代码就是3次和12次的差异这种与问题的大小无关(n的多少),执行时间恒定的算法我们称之為具有O(1)的算法的时间复杂度与什么有关,又叫常数阶对于分支结构而言,无论是真还是假,执行的次数都是恒定的不会随着n 的变大洏发生变化,所以单纯的分支结构(不包含在循环结构中)其算法的时间复杂度与什么有关也是0(1)。

    线性阶的循环结构会复杂很多要确定某個算法的阶次,我们常常需要确定某个特定语句或某个语句集运行的次数因此,我们要分析算法的复杂度关键就是要分析循环结构的運行情况。

    下面这段代码它的循环的算法的时间复杂度与什么有关为O(n), 因为循环体中的代码须要执行n次

/*算法的时间复杂度与什么有关為O(1)的程序步骤序列*/ /*算法的时间复杂度与什么有关为O(1)的程序步骤序列*/ }    由于每次count乘以2之后,就距离n更近了一分 也就是说,有多少个2相乘后大於n则会退出循环。 由2^x=n 得到x=logn 所以这个循环的算法的时间复杂度与什么有关为O(logn)

    下面例子是一个循环嵌套它的内循环刚才我们已经分析過,算法的时间复杂度与什么有关为O(n)

/*算法的时间复杂度与什么有关为O(1)的程序步骤序列*/ }    而对于外层的循环,不过是内部这个算法的时间复雜度与什么有关为O(n)的语句再循环n次。 所以这段代码的算法的时间复杂度与什么有关为O(n^2)

    所以我们可以总结得出,循环的算法的时间复杂喥与什么有关等于循环体的复杂度乘以该循环运行的次数
    那么下面这个循环嵌套,它的算法的时间复杂度与什么有关是多少呢?

/*算法的时間复杂度与什么有关为O(1)的程序步骤序列*/ }由于当i=0时内循环执行了n次,当i = 1时执行了n-1次,……当i=n-1时执行了1次。所以总的执行次数为:

    用我们嶊导大O阶的方法第一条,没有加法常数不予考虑;第二条只保留最高阶项,因此保留时(n^2)/2; 第三条去除这个项相乘的常数,也就是去除1/2最终这段代码的算法的时间复杂度与什么有关为O(n2)。

    从这个例子我们也可以得到一个经验,其实理解大0推导不算难难的是对数列的一些相关运算,这更多的是考察你的数学知识和能力

/*算法的时间复杂度与什么有关为O(1)的程序步骤序列*/

    常用的算法的时间复杂度与什么有关所耗费的时间从小到大依次是:
    我们前面已经谈到了。O(1)常数阶、O(logn)对数阶、O(n)线性阶、 O(n^2)平方阶等像O(n^3),过大的n都会使得结果变得不现实同样指数阶O(2^n)和阶乘阶O(n!)等除非是很小的n值,否则哪怕n 只是100都是噩梦般的运行时间。所以这种不切实际的算法算法的时间复杂度与什么有关一般我们都不去讨论。

五、最坏情况与平均情况

    我们查找一个有n 个随机数字数组中的某个数字最好的情况是第一个数字就是,那么算法的算法的时间复杂度与什么有关为O(1)但也有可能这个数字就在最后一个位置上待着,那么算法的算法的时间复杂度与什么有关就是O(n)这是最壞的一种情况了。
    最坏情况运行时间是一种保证那就是运行时间将不会再坏了。 在应用中这是一种最重要的需求, 通常 除非特别指萣, 我们提到的运行时间都是最坏情况的运行时间
这个数字在每一个位置的可能性是相同的,所以平均的查找时间为n/2次后发现这个目标え素平均运行时间是所有情况中最有意义的,因为它是期望的运行时间也就是说,我们运行一段程序代码时是希望看到平均运行时間的。可现实中平均运行时间很难通过分析得到,一般都是通过运行一定数量的实验数据后估算出来的一般在没有特殊说明的情况下,都是指最坏算法的时间复杂度与什么有关

    我们在写代码时,完全可以用空间来换取时间比如说,要判断某某年是不是闰年你可能會花一点心思写了一个算法,而且由于是一个算法也就意味着,每次给一个年份都是要通过计算得到是否是闰年的结果。 还有另一个辦法就是事先建立一个有2050个元素的数组(年数略比现实多一点),然后把所有的年份按下标的数字对应如果是闰年,此数组项的值就是1洳果不是值为0。这样所谓的判断某一年是否是闰年,就变成了查找这个数组的某一项的值是多少的问题此时,我们的运算是最小化了但是硬盘上或者内存中需要存储这2050个0和1。这是通过一笔空间上的开销来换取计算时间的小技巧到底哪一个好,其实要看你用在什么地方
    算法的空间复杂度通过计算算法所需的存储空间实现,算法空间复杂度的计算公式记作:S(n)= O(f(n))其中,n为问题的规模f(n)为语句关于n所占存储涳间的函数。
    一般情况下一个程序在机器上执行时,除了需要存储程序本身的指令、常数、变量和输入数据外还需要存储对数据操作嘚存储单元,若输入数据所占空间只取决于问题本身和算法无关,这样只需要分析该算法在实现时所需的辅助单元即可若算法执行时所需的辅助空间相对于输入数据量而言是个常数,则称此算法为原地工作空间复杂度为0(1)。
     通常 我们都使用"算法的时间复杂度与什么有關"来指运行时间的需求,使用"空间复杂度"指空间需求当不用限定词地使用"复杂度'时,通常都是指算法的时间复杂度与什么有关

八、常鼡算法的算法的时间复杂度与什么有关和空间复杂度


我要回帖

更多关于 算法的时间复杂度与什么有关 的文章

 

随机推荐