問題:
最近有好幾學生問我,無論是計算機演算法概論、還是資料結構書中,
關於演算法的時間複雜度很多都用包含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)一樣。
沒有非常嚴格的證明,不過我覺得這樣說比較好理解,如果有興趣證明,完全可以參照高數上對極限趨於無窮的證明。
演算法複雜度中的O logN 底數是多少
最近有好幾學生問我,無論是計算機演算法概論 還是資料結構書中,關於演算法的時間複雜度很多都用包含o logn 這樣的描述,但是卻沒有明確說logn 的底數究竟是多少。演算法中log級別的時間複雜度都是由於使用了分治思想,這個底數直接由分治的複雜度決定。如果採用二分法,那麼就會以2為底數,三分法就會以...
演算法複雜度中的O logN 底數是什麼?
演算法中log級別的時間複雜度都是由於使用了分治思想,這個底數直接由分治的複雜度決定。如果採用二分法,那麼就會以2為底數,三分法就會以3為底數,其他亦然。不過無論底數是什麼,log級別的漸進意義是一樣的。也就是說該演算法的時間複雜度的增長與處理資料多少的增長的關係是一樣的。我們先考慮o logx n...
演算法時間複雜度中O logN 的底數是多少
經常在演算法書籍中看到logn的身影,那麼這個對數的底數是多少呢?weiss 在他的著作 資料結構與演算法分析 中曾指出 在電腦科學中,除非有特殊的說明,否則所有的對數都是以2為底的。不過無論底數是什麼,log級別的漸進意義是一樣的。也就是說該演算法的時間複雜度的增長與處理資料多少的增長的關係是一樣...