算法復雜度中的O(logN)底數是多少


前言

     無論是計算機算法概論、還是數據結構書中,關於算法的時間復雜度很多都用包含O(logN)這樣的描述,但是卻沒有明確說logN的底數究竟是多少。算法中log級別的時間復雜度都是由於使用了分治思想,這個底數直接由分治的復雜度決定。如果采用二分法,那么就會以2為底數,三分法就會以3為底數,其他亦然。

     不過無論底數是什么,log級別的漸進意義是一樣的。也就是說該算法的時間復雜度的增長與處理數據多少的增長的關系是一樣的。

     我們先考慮O(logx(n))和O(logy(n)),x!=y,我們是在考慮n趨於無窮的情況。求當n趨於無窮大時logx(n)/logy(n)的極限可以發現,極限等於lny/lnx,也就是一個常數,也就是說,在n趨於無窮大的時候,這兩個東西僅差一個常數。所以從研究算法的角度log的底數不重要。最后,結合上面,我也說一下關於大O的定義(算法導論28頁的定義),注意把這個定義和高等數學中的極限部分做比較,顯然可以發現,這里的定義正是體現了一個極限的思想,假設我們將n0取一個非常大的數字,顯然,當n大於n0的時候,我們可以發現任意底數的一個對數函數其實都相差一個常數倍而已。所以書上說寫的O(logn)已經可以表達所有底數的對數了,就像O(n^2)一樣。沒有非常嚴格的證明,不過我覺得這樣說比較好理解,如果有興趣證明,完全可以參照高數上對極限趨於無窮的證明。

from : 《劍指offer》

 

 

若算法的 T(n) = O(log n),則稱其具有對數時間。由於計算機使用二進制的記數系統,對數常常以10為底(即log10 n,有時寫作 lg n)。然而,由對數的換底公式,loga n和 logb n只有一個常數因子不同,這個因子在大O記法中被丟棄。因此記作O(log n),而不論對數的底是多少,是對數時間算法的標准記法。
 
from: 知乎

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM