青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-3  評(píng)論-5  文章-13  trackbacks-0

--------------------------------------------------------------------------------
標(biāo)題: 關(guān)于平衡二叉樹(AVL tree)旋轉(zhuǎn)后平衡標(biāo)志調(diào)整的計(jì)算公式
作者: 葉飛虎
建立: 2009.10.18
變更: 2010.06.22
--------------------------------------------------------------------------------

1. 引言
      平衡二叉樹的平衡標(biāo)志計(jì)算可以說是最簡(jiǎn)單的, 也可以說是AVL樹中最難的。平衡標(biāo)
   志計(jì)算方法有兩種:
      a. Balance = Height(Left) - Height(Right);
      b. Balance = Height(Right) - Height(Left);

      其中 Height 為結(jié)點(diǎn)的子樹高度(>= 0), 算法簡(jiǎn)單就是說只要左右子樹高度相減即可,
   但運(yùn)行效率不高。當(dāng)結(jié)點(diǎn)數(shù)上千以上時(shí), 頻繁增刪結(jié)點(diǎn)帶來開銷會(huì)相當(dāng)可觀, 正因如此,
   本人通過推理得到的計(jì)算公式就非常重要了。


2. 假設(shè)
   a. 結(jié)點(diǎn)定義
      typedef struct TAVLNode
      {
         void*       Item;          // 存放項(xiàng)
         TAVLNode*   Left;          // 左子結(jié)點(diǎn)
         TAVLNode*   Right;         // 右子結(jié)點(diǎn)
         TAVLNode*   Parent;        // 父結(jié)點(diǎn)
         char        Balance;       // 平衡標(biāo)志: [-1..1]
      } *PAVLNode;

   b. 平衡增量 D 和 D', D 為左子樹增量, D' 為右子樹增量, 且 D = -D', D 可以定義
      為 1 或 -1, 其中:
      1). D = 1  則表示平衡標(biāo)志計(jì)算方法為: Height(Left) - Height(Right)
      2). D = -1 則表示平衡標(biāo)志計(jì)算方法為: Height(Right) - Height(Left)

   c. 結(jié)點(diǎn)高度的函數(shù) H, 則結(jié)點(diǎn) n 有:
      H(n) = M(H(n.Left), H(n.Right)) + D, 同時(shí) H(NULL) = 0
      其中, M(H(n.Left), H(n.Right) 函數(shù)描述如下:
      1). |H(n.Left)| >= |H(n.Right)| 則值為: H(n.Left)
      2). |H(n.Left)| <  |H(n.Right)| 則值為: H(n.Right)

   d. 結(jié)點(diǎn)平衡標(biāo)志的函數(shù) B, 則結(jié)點(diǎn) n 有:
      B(n) = n.Balance = H(n.Left) - H(n.Right)


3. 旋轉(zhuǎn)方式(Left-Left)
   a. 旋轉(zhuǎn)前的樹結(jié)構(gòu)和函數(shù)方程如下:
            (p)               B(p) = H(t) - H(1) = 2D
            / \
          (t) (1)             B(t) = H(n) - H(2)
          / \
        (n) (2)               B(n) = H(3) - H(4)
        / \
      (3) (4)                 同時(shí)必定存在: B(t) != D', 可以用反證法證明.

   b. 旋轉(zhuǎn)后的樹結(jié)構(gòu)和函數(shù)方程如下: (注: 結(jié)點(diǎn) p, t, n 旋轉(zhuǎn)后分別定義為 P, T, N)
          ( T  )              B(T) = H(N) - H(P)
          /    \              B(N) = H(3) - H(4)
        (N)    (P)            B(P) = H(2) - H(1)
        / \    / \
      (3) (4) (2)(1)          同時(shí)必定存在: B(P) != D', 可以用反證法證明.

   c. B(N) 公式
      B(N) = H(3) - H(4)   \
      B(n) = H(3) - H(4)   /  =>    B(N) = B(n) = n.Balance

   d. B(P) 公式
      B(t) = H(n) - H(2)      =>    H(2) = H(n) - B(t)  -+
      B(p) = H(t) - H(1) = 2D =>    H(1) = H(t) - 2D     +
                                    B(P) = H(2) - H(1)  -+

                              =>    B(P) = H(n) - H(t) - B(t) + 2D   \
      由于必定: B(t) != D'    =>    H(t) = H(n) + D                  /
                                 => B(P) = D - B(t) = D - t.Balance

   e. B(T) 公式
      B(t) = H(n) - H(2)      =>    H(n) = B(t) + H(2)  -+
      由于必定: H(N) == H(n)  =>    B(T) = H(n) - H(P)   +
      由于必定: B(P) != D'    =>    H(P) = H(2) + D     -+
                                 => B(T) = B(t) + H(2) - (H(2) + D)
                                 => B(T) = B(t) - D = t.Balance - D

   f. H(T) - H(p) 公式 (即調(diào)整后的高度變化)
      B(T) =  B(t) - D        => B(T) != D
                              => H(T)  = H(P) + D     -+
      H(P) = / H(1) + 2D   當(dāng) B(P) == D                +
             \ H(1) + D    當(dāng) B(P) == 0               -+
                              => H(T) = / H(1) + 3D   當(dāng) B(P) == D   -+
                                        \ H(1) + 2D   當(dāng) B(P) == 0    |
                                                                      + =>
      H(p) = H(t) + D   \                                             |
      H(t) = H(1) + 2D  /     => H(p) = H(1) + 3D                    -+

      H(T) - H(p) = / 0    當(dāng) B(P) == D => B(t) == 0
                    \ -D   當(dāng) B(P) == 0 => B(t) != 0


4. 旋轉(zhuǎn)方式(Left-Right)
   a. 旋轉(zhuǎn)前的樹結(jié)構(gòu)和函數(shù)方程如下:
            (p)               B(p) = H(t) - H(1) = 2D
            / \
          (t) (1)             B(t) = H(2) - H(n)
          / \
        (2) (n)               B(n) = H(3) - H(4)
            / \
          (3) (4)             同時(shí)必定存在: B(t) != D, 可以用反證法證明.

   b. 旋轉(zhuǎn)后的樹結(jié)構(gòu)和函數(shù)方程如下: (注: 結(jié)點(diǎn) p, t, n 旋轉(zhuǎn)后分別定義為 P, T, N)
          ( N  )              B(N) = H(T) - H(P)
          /    \              B(T) = H(2) - H(3)
        (T)    (P)            B(P) = H(4) - H(1)
        / \    / \
      (2) (3) (4)(1)          同時(shí)必定存在: B(P) != D, 可以用反證法證明.

   c. B(T) 公式
      H(n) = / H(3) + 2D      當(dāng) B(n) == D'
             \ H(3) + D       當(dāng) B(n) != D'                    -+
                                                                |
      B(t) = H(2) - H(n)      =>    H(2) = H(n) + B(t)   \      +
                                    B(T) = H(2) - H(3)   /      |
                                 => B(T) = H(n) - H(3) + B(t)  -+

                              =>    B(T) = / B(t) + 2D         當(dāng) B(n) == D'
                                           \ B(t) + D          當(dāng) B(n) != D'

                              =>    B(T) = / t.Balance + 2D    當(dāng) B(n) == D'
                                           \ t.Balance + D     當(dāng) B(n) != D'

   d. B(P) 公式
      H(n) = / H(4) + 2D      當(dāng) B(n) == D
             \ H(4) + D       當(dāng) B(n) != D                     -+
                                                                |
      由于必定: B(t) != D     =>    H(t) = H(n) + D      \      +
      B(p) = H(t) - H(1) = 2D =>    H(1) = H(t) - 2D     /      |
                                 => H(1) = H(n) - D            -+

                              =>    H(1) = / H(4) + D          當(dāng) B(n) == D
                                           \ H(4)              當(dāng) B(n) != D   -+
                                                                               +
                                    B(P) = H(4) - H(1)                        -+

                              =>    B(P) = / D'                當(dāng) B(n) == D
                                           \ 0                 當(dāng) B(n) != D

   e. B(N) 公式
                  +- 2D       當(dāng) B(T) == 2D  -+
      定義 X(T) = +  D        當(dāng) B(T) == D    |
                  +- 0        當(dāng) B(T) == 0    |
                              => X(T) = B(T)  + => H(T) = H(3) + B(T) + D     -+
             +- H(3) + 3D     當(dāng) B(T) == 2D   |                                |
      H(T) = +  H(3) + 2D     當(dāng) B(T) == D    |                                |
             +- H(3) + D      當(dāng) B(T) == 0   -+                                |
                                                   B(N) = H(T) - H(P)          +
      定義 X(P) = / D         當(dāng) B(P) == D'  -+                                |
                  \ 0         當(dāng) B(P) == 0    |                                |
                              => X(P) = -B(P) + => H(P) = H(4) - B(P) + D     -+
      H(P) = / H(4) + 2D      當(dāng) B(P) == D'   |
             \ H(4) + D       當(dāng) B(P) == 0   -+

                              =>    B(N) = H(3) - H(4) + (B(T) + B(P))  \
                                    B(n) = H(3) - H(4)                  /
                                 => B(N) = B(n) + B(T) + B(P)
                                         = n.Balance + B(T) + B(P)

   f. H(N) - H(p) 公式 (即調(diào)整后的高度變化)
      由于 B(T) in {0, D, 2D} => H(T) = H(2) + D
      若 B(n) != D'           => B(N) = B(T) => H(N) = H(T) + D = H(2) + 2D   -+
      若 B(n) == D'           => B(P) = 0                   -+                 |
                                 B(T) = B(t) + 2D            +                 |
                                 B(N) = B(n) + B(T) + B(P)  -+                 +
                                                                               |
                                 => B(N) = B(t) + D => H(N) = H(T) + D         |
                                                            = H(2) + 2D       -+

                                    => H(N) = H(2) + 2D     -+
      H(p) = / H(2) + 2D      當(dāng) B(t) == 0                   + =>
             \ H(2) + 3D      當(dāng) B(t) != 0                  -+

      H(N) - H(p) = / 0       當(dāng) B(t) == 0
                    \ -D      當(dāng) B(t) != 0


5. 旋轉(zhuǎn)方式(Right-Left)
   a. 旋轉(zhuǎn)前的樹結(jié)構(gòu)和函數(shù)方程如下:
      注: 因旋轉(zhuǎn)方式與 (Left-Right) 左右對(duì)稱, 所以推理方法相同, 故省略推理過程
            (p)               B(p) = H(1) - H(t) = 2D'
            / \
          (1) (t)             B(t) = H(n) - H(2)
              / \
            (n) (2)           B(n) = H(3) - H(4)
            / \
          (3) (4)             同時(shí)必定存在: B(t) != D', 可以用反證法證明.

   b. 旋轉(zhuǎn)后的樹結(jié)構(gòu)和函數(shù)方程如下: (注: 結(jié)點(diǎn) p, t, n 旋轉(zhuǎn)后分別定義為 P, T, N)
          ( N  )              B(N) = H(T) - H(P)
          /    \              B(P) = H(1) - H(3)
        (P)    (T)            B(T) = H(4) - H(2)
        / \    / \
      (1) (3) (4)(2)          同時(shí)必定存在: B(P) != D', 可以用反證法證明.

   c. B(T) 公式
      B(T) = / t.Balance + 2D'當(dāng) B(n) == D
             \ t.Balance + D' 當(dāng) B(n) != D

   d. B(P) 公式
      B(P) = / D              當(dāng) B(n) == D'
             \ 0              當(dāng) B(n) != D'

   e. B(N) 公式
      B(N) = n.Balance + B(P) + B(T)

   f. H(N) - H(p) 公式 (即調(diào)整后的高度變化)
      H(N) - H(p) = / 0       當(dāng) B(t) == 0
                    \ -D      當(dāng) B(t) != 0


6. 旋轉(zhuǎn)方式(Right-Right)
   a. 旋轉(zhuǎn)前的樹結(jié)構(gòu)和函數(shù)方程如下:
      注: 因旋轉(zhuǎn)方式與 (Left-Left) 左右對(duì)稱, 所以推理方法相同, 故省略推理過程
            (p)               B(p) = H(1) - H(t) = 2D'
            / \
          (1) (t)             B(t) = H(2) - H(n)
              / \
            (2) (n)           B(n) = H(3) - H(4)
                / \
              (3) (4)         同時(shí)必定存在: B(t) != D, 可以用反證法證明.

   b. 旋轉(zhuǎn)后的樹結(jié)構(gòu)和函數(shù)方程如下: (注: 結(jié)點(diǎn) p, t, n 旋轉(zhuǎn)后分別定義為 P, T, N)
          ( T  )              B(T) = H(P) - H(N)
          /    \              B(P) = H(1) - H(2)
        (P)    (N)            B(N) = H(3) - H(4)
        / \    / \
      (1) (2) (3)(4)          同時(shí)必定存在: B(P) != D, 可以用反證法證明.

   c. B(N) 公式
      B(N) = B(n) = n.Balance

   d. B(P) 公式
      B(P) = D' - B(t) = D' - t.Balance

   e. B(T) 公式
      B(T) = B(t) - D' = t.Balance - D'

   f. H(T) - H(p) 公式 (即調(diào)整后的高度變化)
      B(T) =  B(t) - D'       => B(T) != D'
                              => H(T)  = H(P) + D     -+
      H(P) = / H(1) + 2D   當(dāng) B(P) == D'               +
             \ H(1) + D    當(dāng) B(P) == 0               -+
                              => H(T) = / H(1) + 3D   當(dāng) B(P) == D'  -+
                                        \ H(1) + 2D   當(dāng) B(P) == 0    |
                                                                      + =>
      H(p) = H(t) + D   \                                             |
      H(t) = H(1) + 2D  /     => H(p) = H(1) + 3D                    -+

      H(T) - H(p) = / 0    當(dāng) B(P) == D'=> B(t) == 0
                    \ -D   當(dāng) B(P) == 0 => B(t) != 0


7. 增/刪結(jié)點(diǎn)的要點(diǎn)分析
   a. 插入結(jié)點(diǎn)
      插入結(jié)點(diǎn)沿著根結(jié)點(diǎn)向上增加平衡值, 若檢測(cè)到 p 為 2D 或 2D' 時(shí), 只要使用 LL,
   LR, RL, 或 RR 中的一種旋轉(zhuǎn)調(diào)整平衡值, 且只要需要一次即可并中止向上增加平衡值.

   b. 刪除結(jié)點(diǎn)
      1). 由于 LR 旋轉(zhuǎn), 若 B(t) == 0 且 B(n) == D' 時(shí), 則存在 B(T) = 2D 即失去平
         衡, 所以在刪除結(jié)點(diǎn)若遇到 B(t) == 0 時(shí)就改為 LL 旋轉(zhuǎn)即可避開 B(T) = 2D;

      2). 由于 RL 旋轉(zhuǎn), 若 B(t) == 0 且 B(n) == D 時(shí), 則存在 B(T) = 2D' 即失去平
         衡, 所以在刪除結(jié)點(diǎn)若遇到 B(t) == 0 時(shí)就改為 RR 旋轉(zhuǎn)即可避開 B(T) = 2D';

      3). 刪除結(jié)點(diǎn)沿著根結(jié)點(diǎn)向上減去平衡值, 若檢測(cè)到 p 為 2D 或 2D' 時(shí), 只要使用
         LL, LR, RL, 或 RR 中的一種旋轉(zhuǎn)調(diào)整平衡值, 當(dāng) B(t) == 0 時(shí)中止向上減去平
         衡值, 否則必須向上減去平衡值.

 

posted on 2011-05-22 10:44 Kyee Ye 閱讀(645) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 算法

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲图片你懂的| 狠狠做深爱婷婷久久综合一区| 国产在线日韩| 久久免费观看视频| 免费观看在线综合| 亚洲午夜精品网| 久久av一区二区三区亚洲| 亚洲大胆女人| 一区二区三区高清视频在线观看| 国产精品日韩一区二区| 麻豆精品在线观看| 欧美午夜美女看片| 在线欧美亚洲| 亚洲综合色自拍一区| 亚洲精品视频一区| 欧美一站二站| 亚洲免费视频在线观看| 久久婷婷国产麻豆91天堂| 亚洲欧美日韩天堂| 欧美精品 国产精品| 久久久久久久综合日本| 国产精品二区影院| 亚洲国产视频a| 国产日韩欧美精品在线| 亚洲欧洲在线观看| 亚洲国产精品电影| 亚洲欧美日韩国产综合| 9l国产精品久久久久麻豆| 久久嫩草精品久久久精品一| 欧美一区国产二区| 欧美日韩国产成人精品| 欧美激情一区二区三区在线视频观看 | 免费看av成人| 欧美一区二区在线播放| 欧美日韩黄色大片| 亚洲电影专区| 亚洲成人在线免费| 久久精品国产亚洲aⅴ| 亚洲女同精品视频| 欧美日韩xxxxx| 亚洲国产精品久久久| 在线成人黄色| 久久精品免费观看| 欧美中文在线视频| 国产区二精品视| 亚洲网站在线看| 亚洲欧美偷拍卡通变态| 国产精品成人播放| 一区二区三区毛片| 亚洲手机在线| 国产精品theporn88| 亚洲小视频在线| 久久精彩视频| 国内精品久久久| 久久精品在线免费观看| 久久综合一区二区| 亚洲高清电影| 欧美成人免费小视频| 91久久久久久久久久久久久| 亚洲美女诱惑| 欧美午夜在线| 亚洲欧美美女| 久久综合九九| 亚洲人人精品| 欧美午夜精品| 欧美一级大片在线观看| 久久久精品免费视频| 狠狠色综合一区二区| 免费人成网站在线观看欧美高清| 蜜臀久久久99精品久久久久久| 精品电影在线观看| 欧美激情一二区| 亚洲性av在线| 久久这里有精品视频| 亚洲国产免费看| 欧美色另类天堂2015| 亚洲字幕一区二区| 久久久久国产精品一区| 91久久嫩草影院一区二区| 欧美婷婷在线| 久久精品天堂| 一区二区三区高清在线观看| 欧美一区91| 亚洲国产一区二区三区在线播| 欧美视频在线看| 久久精品99无色码中文字幕| 亚洲韩日在线| 午夜伦理片一区| 亚洲国产高清在线| 国产精品国产成人国产三级| 久久国产夜色精品鲁鲁99| 亚洲毛片av| 久久色在线播放| 亚洲一区三区电影在线观看| 亚洲盗摄视频| 国产精品亚洲综合| 欧美jjzz| 欧美中日韩免费视频| 亚洲免费观看高清在线观看 | 久久久亚洲国产天美传媒修理工| 亚洲风情在线资源站| 亚洲欧美日韩精品一区二区 | 久久本道综合色狠狠五月| 亚洲国产欧美久久| 久久福利精品| 在线亚洲观看| 亚洲激情网站免费观看| 国产精品成人在线| 欧美精品激情在线| 久久精品国产亚洲精品| 日韩一级大片在线| 欧美激情亚洲综合一区| 久久精品亚洲精品| 亚洲自拍偷拍麻豆| 亚洲精品人人| 在线观看欧美日韩| 国产午夜精品理论片a级大结局 | 久久人人爽人人爽| 亚洲欧美日韩国产一区| 亚洲美女精品一区| 在线观看日韩www视频免费| 国产伦精品一区二区三区在线观看| 欧美激情一区二区三区四区| 久久精品天堂| 欧美一区二区三区在| 亚洲欧美国产日韩天堂区| 亚洲线精品一区二区三区八戒| 亚洲欧洲三级| 91久久综合亚洲鲁鲁五月天| 美女精品国产| 久久免费视频网站| 久久久www免费人成黑人精品| 午夜精品国产更新| 午夜伦欧美伦电影理论片| 亚洲小说欧美另类社区| 日韩亚洲欧美精品| 亚洲欧洲精品一区二区精品久久久| 尤物精品在线| 在线播放豆国产99亚洲| 在线日韩精品视频| 国产自产v一区二区三区c| 国产私拍一区| 激情欧美一区二区| 亚洲国产成人精品女人久久久| 国模套图日韩精品一区二区| 国产日韩在线播放| 激情欧美国产欧美| 最新国产成人在线观看| 91久久精品国产91久久性色| 91久久夜色精品国产网站| 亚洲巨乳在线| 一区二区三区欧美成人| 亚洲专区一区| 久久精品欧美日韩| 美女黄毛**国产精品啪啪| 亚洲第一精品在线| 亚洲精品在线观看免费| 一本久久综合| 亚洲欧美日韩精品综合在线观看| 午夜精品久久久| 久久久久9999亚洲精品| 免费短视频成人日韩| 欧美成人高清视频| 国产精品啊啊啊| 国产永久精品大片wwwapp| 激情五月综合色婷婷一区二区| 亚洲第一页自拍| 亚洲手机在线| 久久久午夜精品| 亚洲激情视频网| 亚洲欧美日韩天堂一区二区| 久久久噜久噜久久综合| 欧美激情在线免费观看| 国产精品中文字幕在线观看| 玉米视频成人免费看| 一区二区高清在线观看| 久久精品2019中文字幕| 亚洲国产毛片完整版| 亚洲天堂av高清| 老司机午夜精品视频| 国产精品久久久久久亚洲调教| 一区一区视频| 亚洲免费一区二区| 欧美激情视频一区二区三区在线播放| 一本一本久久| 免费成人在线观看视频| 国产欧美高清| 一区二区高清视频| 免播放器亚洲一区| 亚洲欧美日韩综合国产aⅴ| 蜜桃久久精品乱码一区二区| 国产欧美日韩精品丝袜高跟鞋| 最近中文字幕日韩精品 | 国产精品人人做人人爽| 亚洲高清资源综合久久精品| 亚洲欧美日韩一区二区三区在线| 欧美激情第8页| 久久国产精品久久久久久久久久 | 亚洲一区久久久| 亚洲一区二区视频在线|