大O符号

来自testwiki
跳转到导航 跳转到搜索

Template:No footnotes Template:NoteTA 大O符号Template:Lang-en),又稱為漸近符號,是用于描述函数渐近行为数学符号。更确切地说,它是用另一个(通常更简单的)函数来描述一个函数数量级渐近上界。在数学中,它一般用来刻画被截断的无穷级数尤其是渐近级数的剩余项;在计算机科学中,它在分析算法复杂性的方面非常有用。

大O符号是由德国数论学家保罗·巴赫曼在其1892年的著作《解析数论》(Analytische Zahlentheorie)首先引入的。而这个记号则是在另一位德国数论学家愛德蒙·蘭道的著作中才推广的,因此它有时又称为蘭道符号(Landau symbols)。代表“order of ...”(……阶)的大O,最初是一个大写希腊字母Ο”(omicron),现今用的是大写拉丁字母O”。

使用

无穷大渐近

大O符号在分析算法效率的时候非常有用。举个例子,解决一个规模为n的问题所花费的时间(或者所需步骤的数目)可以表示為:T(n)=4n22n+2。当n增大时,n2项将开始占主导地位,而其他各项可以被忽略。举例说明:当n=5004n2项是2n项的1000倍大,因此在大多数场合下,省略后者对表达式的值的影响将是可以忽略不计的。

进一步看,如果我们与任一其他级的表达式比较,n2项的系数也是无关紧要的。例如:一个包含n3n2项的表达式,即使T(n)=1,000,000n2,假定U(n)=n3,一旦n增长到大于1,000,000,后者就会一直超越前者(T(1,000,000)=1,000,0003=U(1,000,000))。


这样,針對第一個例子T(n)=4n22n+2,大O符号就记下剩余的部分,写作:

T(n)O(n2)

T(n)=O(n2)

并且我们就说该算法具有n2阶(平方阶)的时间复杂度

无穷小渐近

大O也可以用来描述数学函数估计中的误差项。例如ex泰勒展开

ex=1+x+x22+O(x3)x0

这表示,如果x足够接近于0,那么误差ex(1+x+x22)绝对值小于x3的某一常数倍。

注:泰勒展开的误差余项r3(x)是关于x3一个高阶无穷小量,用小o来表示,即:r3(x)=o(x3),也就是limx0r3(x)x3=0.

形式化定义

給定兩個定義在實數某子集上的關於x的函數f(x)g(x),當x趨近於無窮大時,存在正实數M,使得對於所有Template:Lex,都有f(x)的絕對值小於等於M乘以g(x)的絕對值,那麼我們就可以說,當x時,

f(x)=O(g(x))

也就是說,假如存在正實數M和實數x0,使得對於所有的xx0,均有:|f(x)| M|g(x)|成立,我們就可以認爲,f(x)=O(g(x))

在很多情況下,我們會省略“當x趨近於無限大時”這個前提,而簡寫爲:

f(x)=O(g(x))

此概念也可以用於描述函數f在接近實數a時的行爲,通常a=0。當我們說,當xa時,有f(x)=O(g(x)),也就相當於稱,當且僅當存在正實數M和實數δ,使得對於所有的0|xa|δ,均有|f(x)| M|g(x)|成立。

如果當xa足夠接近時,g(x)的值仍不爲0,這兩種定義就可以統一用上極限來表示:

當且僅當lim supxa|f(x)g(x)|<時,有f(x)=O(g(x))

例子

在具体的运用中,我们不一定使用大O符号的标准定义,而是使用几条简化规则来求出关于函数f的大O表示:

  • 假如f(x)是几项之和,那么只保留增长最快(通常是阶最高)的项,其他项省略。
  • 假如f(x)是几项之积,那么常数(不取决于x的乘数)省略。

比如,使f(x)=6x42x3+5,我们想要用大O符号来简化这个函数,来描述x接近无穷大时函数的增长情况。此函数由三项相加而成,6x42x35。由于增长最快的是6x4这一项(因为阶最高,在x接近无穷大时,其对和的影响会大大超过其余两项),应用第一条规则,保留它而省略其他两项。对于6x4,由两项相乘而得,6x4;应用第二条规则,6是无关x的常数,所以省略。最后结果为x4,也即g(x)=x4。故有:

f(x)=O(g(x)),可得:
6x42x3+5=O(x4)

我们可以将上式扩展为标准定义形式:

对任意xx0,均有|f(x)|M|g(x)|,也就是6x42x3+5M|x4|

可以(粗略)求出Mx0的值来验证。使x0=1

|6x42x3+5|6x4+|2x3|+56x4+2x4+5x413x4

M可以为13。故两者都存在。

常用的函数阶

下面是在分析算法的时候常见的函数分类列表。所有这些函数都处于n趋近于无穷大的情况下,增长得慢的函数列在上面。c是一个任意常数。

符号 名称
O(1) 常数(阶,下同)
O(logn) 对数
O[(logn)c] 多对数
O(n) 线性,次线性
O(nlog*n) log*n迭代对数
O(nlogn) 线性对数,或对数线性、拟线性、超线性
O(n2) 平方
O(nc),Integer(c>1) 多项式,有时叫作“代数”(阶)
O(cn) 指數,有时叫作“几何”(阶)
O(n!) 阶乘,有时叫做“组合”(阶)

一些相关的渐近符号

大O是最经常使用的比较函数的渐近符号。

符号 定义
f(n)=O(g(n)) 渐近上限
f(n)=o(g(n)) Asymptotically negligible渐近可忽略不计(limf(n)g(n)=0
f(n)=Ω(g(n)) 渐近下限(当且仅当g(n)=O(f(n))
f(n)=ω(g(n)) Asymptotically dominant渐近主导(当且仅当g(n)=o(f(n))
f(n)=Θ(g(n)) Asymptotically tight bound渐近紧约束(当且仅当f(n)=O(g(n))f(n)=Ω(g(n))

注意

大O符号经常被误用:有的作者可能会使用大O符号表达大Θ符号的含义。因此在看到大O符号时应首先确定其是否为误用。

参看

参考文献

引用

Template:Reflist

来源

Template:Refbegin

书籍
  • 严蔚敏、吴伟民:《数据结构:C语言版》. 清华大学出版社,1996. ISBN 7-302-02368-9. 1.4节 算法和算法分析,pp. 14-17.
  • 朱青:《計算機算法與程序設計》. 清华大学出版社,2009.10。ISBN 978-7-302-20267-7. 1.4节 算法的複雜性分析,pp. 16-17.

Template:Refend

延伸閱讀

Template:Refbegin

Template:Refend