时间频度与时间复杂度.doc

时间频度与时间复杂度.doc

ID:57644153

大小:44.50 KB

页数:5页

时间:2020-08-30

时间频度与时间复杂度.doc_第1页
时间频度与时间复杂度.doc_第2页
时间频度与时间复杂度.doc_第3页
时间频度与时间复杂度.doc_第4页
时间频度与时间复杂度.doc_第5页
资源描述:

《时间频度与时间复杂度.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、1)时间频度一个算法执行所耗费的时间,从理论上是不能算出来的,必须上机运行测试才能知道。但我们不可能也没有必要对每个算法都上机测试,只需知道哪个算法花费的时间多,哪个算法花费的时间少就可以了。并且一个算法花费的时间与算法中语句的执行次数成正比例,哪个算法中语句执行次数多,它花费时间就多。一个算法中的语句执行次数称为语句频度或时间频度。记为T(n)。(2)时间复杂度在刚才提到的时间频度中,n称为问题的规模,当n不断变化时,时间频度T(n)也会不断变化。但有时我们想知道它变化时呈现什么规律。为此,我们引入时间复杂度概念

2、。一般情况下,算法中基本操作重复执行的次数是问题规模n的某个函数,用T(n)表示,若有某个辅助函数f(n),使得当n趋近于无穷大时,T(n)/f(n)的极限值为不等于零的常数,则称f(n)是T(n)的同数量级函数。记作T(n)=O(f(n)),称O(f(n))为算法的渐进时间复杂度,简称时间复杂度。在各种不同算法中,若算法中语句执行次数为一个常数,则时间复杂度为O(1),另外,在时间频度不相同时,时间复杂度有可能相同,如T(n)=n^2+3n+4与T(n)=4n^2+2n+1它们的频度不同,但时间复杂度相同,都为O

3、(n^2)。按数量级递增排列,常见的时间复杂度有:常数阶O(1),对数阶O(log(2)n),线性阶O(n),线性对数阶O(nlog(2)n),平方阶O(n^2),立方阶O(n^3),...,k次方阶O(n^k),指数阶O(2^n)。随着问题规模n的不断增大,上述时间复杂度不断增大,算法的执行效率越低。(3)算法的时间复杂度若要比较不同的算法的时间效率,受限要确定一个度量标准,最直接的办法就是将计算法转化为程序,在计算机上运行,通过计算机内部的计时功能获得精确的时间,然后进行比较。但该方法受计算机的硬件、软件等因素

4、的影响,会掩盖算法本身的优劣,所以一般采用事先分析估算的算法,即撇开计算机软硬件等因素,只考虑问题的规模(一般用用自然数n表示),认为一个特定的算法的时间复杂度,只采取于问题的规模,或者说它是问题的规模的函数。为了方便比较,通常的做法是,从算法选取一种对于所研究的问题(或算法模型)来说是基本运算的操作,以其重复执行的次数作为评价算法时间复杂度的标准。该基本操作多数情况下是由算法最深层环内的语句表示的,基本操作的执行次数实际上就是相应语句的执行次数。一般T(n)=O(f(n))O(1)

5、(nlog2n)

6、费时间就多。一个算法中的语句执行次数称为语句频度或时间频度。记为T(n)。2.计算方法1.一般情况下,算法的基本操作重复执行的次数是模块n的某一个函数f(n),因此,算法的时间复杂度记做:T(n)=O(f(n))  分析:随着模块n的增大,算法执行的时间的增长率和f(n)的增长率成正比,所以f(n)越小,算法的时间复杂度越低,算法的效率越高。  2.在计算时间复杂度的时候,先找出算法的基本操作,然后根据相应的各语句确定它的执行次数,再找出T(n)的同数量级(它的同数量级有以下:1,Log2n,n,nLog2n,n的

7、平方,n的三次方,2的n次方,n!),找出后,f(n)=该数量级,若T(n)/f(n)求极限可得到一常数c,则时间复杂度T(n)=O(f(n))  例:算法:  for(i=1;i<=n;++i)  {  for(j=1;j<=n;++j)  {  c[i][j]=0;//该步骤属于基本操作执行次数:n的平方次  for(k=1;k<=n;++k)  c[i][j]+=a[i][k]*b[k][j];//该步骤属于基本操作执行次数:n的三次方次  }  }  则有T(n)=n的平方+n的三次方,根据上面括号里的同数

8、量级,我们可以确定n的三次方为T(n)的同数量级  则有f(n)=n的三次方,然后根据T(n)/f(n)求极限可得到常数c  则该算法的时间复杂度:T(n)=O(n的三次方)3.分类  按数量级递增排列,常见的时间复杂度有:  常数阶O(1),对数阶O(log2n),线性阶O(n),  线性对数阶O(nlog2n),平方阶O(n2),立方阶O(n3),...

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

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

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