大O符号
注:“order”在全文中被译为“阶”,也可以另译为“数量级”。
大O符号(Big O notation)是用于描述函数渐近行为的数学符号。更确切地说,它是用另一个(通常更简单的)函数来描述一个函数数量级的渐近上界。在数学中,它一般用来刻画被截断的无穷级数尤其是渐近级数的剩余项;在计算机科学中,它在分析算法复杂性的方面非常有用。
大O符号是由德国数论学家保罗·巴赫曼(Paul Bachmann)在其1892年的著作《解析数论》(Analytische Zahlentheorie)首先引入的。而这个记号则是在另一位德国数论学家艾德蒙·朗道(Edmund Landau)的著作中才推广的,因此它有时又称为朗道符号(Landau symbols)。代表“order of ...”(……阶)的大 O,最初是一个大写的希腊字母'Ο'(Omicron),现今用的是大写拉丁字母‘O’,但从来不是阿拉伯数字 ‘0’。
目录 |
使用[编辑]
这个符号有两种形式上很接近但迥然不同的使用方法:无穷大渐近与无穷小渐近。然而这个区别只是在运用中的而不是原则上的——除了对函数自变量的一些不同的限定, “大O”的形式定义在两种情况下都是相同的。[來源請求]
无穷大渐近[编辑]
大O符号在分析算法效率的时候非常有用。举个例子,解决一个规模为
的问题所花费的时间(或者所需步骤的数目)可以表示為:
。当
增大时,
项将开始占主导地位,而其他各项可以被忽略。 举例说明:当
,
项是
项的1000倍大,因此在大多数场合下,省略后者对表达式的值的影响将是可以忽略不计的。
进一步看,如果我们与任一其他级的表达式比较,
项的系数也是无关紧要的。例如:一个包含
或
项的表达式,即使
,假定
,一旦
增长到大于 1,000,000,后者就会一直超越前者(
)。
这样,大O符号就记下剩余的部分,写作:
或
并且我们就说该算法具有
阶(平方阶)的时间复杂度。
无穷小渐近[编辑]
大O也可以用来描述数学函数估计中的误差项。例如
的泰勒展开:
当
时
这表示,如果
足够接近于0,那么误差
的绝对值小于
的某一常数倍。
形式化定义[编辑]
給定兩正值函數
和
, 定義:
, 條件為: 存在正數
和
, 使得對於所有的
, 有
上述的定義表明,當
足夠大,大過一個特定的
時,且存在一個正數
, 使得
不大於
, 則
是
的
表示。
和
的關係可以理解為
是
的一個上界,也可以理解為
最終至多增漲的速度與
一樣快,但不會超過
的增漲速度。
常用的函数阶[编辑]
下面是在分析算法的时候常见的函数分类列表。所有这些函数都处于
趋近于无穷大的情况下,增长得慢的函数列在上面。
是一个任意常数。
| 符号 | 名称 |
|---|---|
![]() |
常数(阶,下同) |
![]() |
迭代对数 |
![]() |
对数 |
![]() |
多对数 |
![]() |
线性,次线性 |
![]() |
线性对数,或对数线性、拟线性、超线性 |
![]() |
平方 |
![]() |
多项式,有时叫作“代数”(阶) |
![]() |
指数,有时叫作“几何”(阶) |
![]() |
阶乘,有时叫做“组合”(阶) |
一些相关的渐近符号[编辑]
大O是最经常使用的比较函数的渐近符号。
| 符号 | 定义 |
|---|---|
![]() |
渐近上限 |
![]() |
asymptotically negligible ( ) |
![]() |
渐近下限 (当且仅当 ) |
![]() |
asymptotically dominant (当且仅当 ) |
![]() |
asymptotically tight bound (当且仅当 且 ) |
注意[编辑]
大O符号经常被误用:有的作者可能会使用大O符号表达大Θ符号的含义。因此在看到大O符号时应首先确定其是否为误用。
参看[编辑]
参考资料[编辑]
- 严蔚敏,吴伟民。数据结构:C语言版。北京清华大学出版社,1996。ISBN 7-302-02368-9。1.4节 算法和算法分析,14-17页。
- 朱青。計算機算法與程序設計。北京清华大学出版社,2009.10。ISBN 978-7-302-20267-7。1.4节 算法的複雜性分析,16-17页。


当
时
, 條件為: 存在正數
, 有



![\Omicron[(\log n)^c]\!](http://upload.wikimedia.org/math/a/1/2/a1290e02605a773cc41b2583baa2c678.png)







)
)
)