時間複雜度O(1)、O(n)、O(n²)、O(nlogn)的含義
在描述演算法複雜度時,經常用到o(1), o(n), o(logn), o(nlogn)來表示對應演算法的時間複雜度, 這裡進行歸納一下它們代表的含義:
這是演算法的時空複雜度的表示。不僅僅用於表示時間複雜度,也用於表示空間複雜度。
O後面的括號中有一個函式,指明某個演算法的耗時/耗空間與資料增長量之間的關係。其中的n代表輸入資料的量。
比如時間複雜度為O(n),就代表資料量增大幾倍,耗時也增大幾倍。比如常見的遍歷演算法。
再比如時間複雜度O(n^2),就代表資料量增大n倍時,耗時增大n的平方倍,這是比線性更高的時間複雜度。比如氣泡排序,就是典型的O(n^2)的演算法,對n個數排序,需要掃描n×n次。
再比如O(logn),當資料增大n倍時,耗時增大logn倍(這裡的log是以2為底的,比如,當資料增大256倍時,耗時只增大8倍,是比線性還要低的時間複雜度)。二分查詢就是O(logn)的演算法,
每找一次排除一半的可能,256個資料中查詢只要找8次就可以找到目標。
O(nlogn)同理,就是n乘以logn,當資料增大256倍時,耗時增大256*8=2048倍。這個複雜度高於線性低於平方。歸併排序就是O(nlogn)的時間複雜度。
O(1)就是最低的時空複雜度了,也就是耗時/耗空間與輸入資料大小無關,無論輸入資料增大多少倍,耗時/耗空間都不變。 雜湊演算法就是典型的O(1)時間複雜度,無論資料規模多大,都可以
在一次計算後找到目標(不考慮衝突的話)
附:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/15498/viewspace-2645728/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 演算法中的O(1), O(n),O(logn), O(nlogn)演算法
- 時間複雜度O(n)和空間複雜度時間複雜度
- 正規表示式時間複雜度O(n)時間複雜度
- 時間複雜度為 O (n^2) 的排序演算法時間複雜度排序演算法
- 時間複雜度為 O(n^2) 的排序演算法時間複雜度排序演算法
- 時間複雜度為O(nlogn)的排序演算法時間複雜度排序演算法
- 快速排序平均時間複雜度O(nlogn)的推導排序時間複雜度
- 時間複雜度為 O(nlogn) 的排序演算法時間複雜度排序演算法
- Java實現:排序演算法--時間複雜度為O(n² )Java排序演算法時間複雜度
- 判斷連結串列是否為迴文結構,空間負責度為O(1),時間複雜度為O(n)時間複雜度
- 一道看上去很嚇人的演算法面試題:如何對n個數進行排序,要求時間複雜度O(n),空間複雜度O(1)演算法面試題排序時間複雜度
- 線性時間選擇(含平均情況O(n)和最壞情況O(n)演算法)演算法
- O(n)-O(1) 線性 RMQ 學習筆記MQ筆記
- Leetcode 234. 迴文連結串列 快慢指標+連結串列逆序實現O(n)時間複雜度且O(1)空間複雜度LeetCode指標時間複雜度
- LCA Online Query with O(N) Memory and O(1) Time Complexity
- 【演算法資料結構Java實現】時間複雜度為O(n)的最大和序列演算法資料結構Java時間複雜度
- 隨機列印0-100的全部數字並且不可重複,時間複雜度為O(n)隨機時間複雜度
- O(n^2)的排序演算法排序演算法
- 【演算法】設計包含 min函式的棧,時間複雜度都是 O(1)演算法函式時間複雜度
- 【漫畫】為什麼說O(n)複雜度的基數排序沒有快速排序快?複雜度排序
- 二叉樹的 Morris 中序遍歷——O(1)空間複雜度二叉樹複雜度
- JavaScript 排序演算法(O log(N)等)JavaScript排序演算法
- InnoDB: Error: space id and page n:o stored in the page?Error
- o(* ̄- ̄*)o
- 用機器學習構建O(N)複雜度的排序演算法,可在GPU和TPU上加速計算機器學習複雜度排序演算法GPU
- Algorithm 04 : 尋找兩個有序陣列中的第N個數,要求時間複雜度為O(logm+logn)Go陣列時間複雜度
- 演算法與資料結構--空間複雜度O(1)遍歷樹演算法資料結構複雜度
- o2o系統 本地生活服務 微信o2o
- 高投入佈局O2O致使股價大跌,百度O2O是否仍有機會
- 演算法題:O(1)時間複雜度實現獲取棧的最大值、最小值演算法時間複雜度
- Codeforces 486D Valid Sets:Tree dp【n遍O(n)的dp】
- 記一次Redis O(n)命令拖慢介面Redis
- 動態規劃實現O(n)爆破任意加密動態規劃加密
- 【面試】I/O 複用面試
- 額外空間複雜度O(1) 的二叉樹遍歷 → Morris Traversal,你造嗎?複雜度二叉樹
- 一個整型陣列裡除了一個或者兩個或者三個數字之外,其他的數字都出現了兩次。請寫程式找出這兩個只出現一次的數字。要求時間複雜度是O(n),空間複雜度是O(1)陣列時間複雜度
- 為什麼堆化 heapify() 只用 O(n) 就做到了?API
- 佳弗O2O系統