完全二叉樹的高度為什么是對lgN向下取整


完全二叉樹的高度為什么是對lgN向下取整呢?

說明一下這里的高度:只有根節點的樹高度是0。

設一棵完全二叉樹節點個數為N,高度為h。所以總節點個數N滿足以下不等式:

1 + 21 + 22 +……+ 2h-1 < N <= 1 + 21 + 22 +……+ 2即 2h - 1 < N <= 2h+1 - 1,所以 2h < N+1 <= 2h+1,兩邊同取以2為底的對數得 h < log2(N+1) <= h+1。


若 N+1 = 2k ,此時完全二叉樹為滿二叉樹,解上述不等式得 h < k <= h+1,所以 k-1 <= h < k,所以 h = k-1。而 log2N = log2(2k -1),又因為比 2k -1 小且離其最近的2的冪是 2k-1 

所以 log2N> log2(2k-1) = k-1,因此對 log2N 向下取整即為 k-1,即二叉樹的高度等於對 log2N 向下取整。


若 N+1 不等於2的冪,設2k-1 < N+1 < 2k,所以 k-1 < log2(N+1) < k,所以 k-2 < h < k,所以 h = k-1。設此時對應的滿二叉樹節點數為N0,所以 k-1 = 對log2N0向下取整,

h = k-1 也等於對log2N0向下取整。因為 N > 2k-1 -1,即 N >= 2k-1,N0 <= 2k -1,所以對log2N0向下取整等於對 log2N 向下取整。所以二叉樹的高度等於對 log2N 向下取整。


證畢。


免責聲明!

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



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