日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

数据结构之AVL树

發(fā)布時(shí)間:2025/3/21 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数据结构之AVL树 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
1. 概述

AVL樹是最早提出的自平衡二叉樹,在AVL樹中任何節(jié)點(diǎn)的兩個(gè)子樹的高度最大差別為一,所以它也被稱為高度平衡樹。AVL樹得名于它的發(fā)明者G.M. Adelson-Velsky和E.M. Landis。AVL樹種查找、插入和刪除在平均和最壞情況下都是O(log n),增加和刪除可能需要通過一次或多次樹旋轉(zhuǎn)來重新平衡這個(gè)樹。本文介紹了AVL樹的設(shè)計(jì)思想和基本操作。

2. 基本術(shù)語

有四種種情況可能導(dǎo)致二叉查找樹不平衡,分別為:

(1)LL:插入一個(gè)新節(jié)點(diǎn)到根節(jié)點(diǎn)的左子樹(Left)的左子樹(Left),導(dǎo)致根節(jié)點(diǎn)的平衡因子由1變?yōu)?

(2)RR:插入一個(gè)新節(jié)點(diǎn)到根節(jié)點(diǎn)的右子樹(Right)的右子樹(Right),導(dǎo)致根節(jié)點(diǎn)的平衡因子由-1變?yōu)?2

(3)LR:插入一個(gè)新節(jié)點(diǎn)到根節(jié)點(diǎn)的左子樹(Left)的右子樹(Right),導(dǎo)致根節(jié)點(diǎn)的平衡因子由1變?yōu)?

(4)RL:插入一個(gè)新節(jié)點(diǎn)到根節(jié)點(diǎn)的右子樹(Right)的左子樹(Left),導(dǎo)致根節(jié)點(diǎn)的平衡因子由-1變?yōu)?2

針對(duì)四種種情況可能導(dǎo)致的不平衡,可以通過旋轉(zhuǎn)使之變平衡。有兩種基本的旋轉(zhuǎn):

(1)左旋轉(zhuǎn):將根節(jié)點(diǎn)旋轉(zhuǎn)到(根節(jié)點(diǎn)的)右孩子的左孩子位置

(2)右旋轉(zhuǎn):將根節(jié)點(diǎn)旋轉(zhuǎn)到(根節(jié)點(diǎn)的)左孩子的右孩子位置

3. AVL樹的旋轉(zhuǎn)操作

AVL樹的基本操作是旋轉(zhuǎn),有四種旋轉(zhuǎn)方式,分別為:左旋轉(zhuǎn),右旋轉(zhuǎn),左右旋轉(zhuǎn)(先左后右),右左旋轉(zhuǎn)(先右后左),實(shí)際上,這四種旋轉(zhuǎn)操作兩兩對(duì)稱,因而也可以說成兩類旋轉(zhuǎn)操作。

基本的數(shù)據(jù)結(jié)構(gòu):

1 2 3 4 5 6 7 8 9 10 11 12 13 typedef struct Node* Tree; typedef struct Node* Node_t; typedef Type int; struct Node{ ?Node_t left; ?Node_t right; ?int height; ?Type data; }; int Height(Node_t node) { ?return node->height; }

3.1 LL

LL情況需要右旋解決,如下圖所示:

代碼為:

1 2 3 4 5 6 7 8 Node_t RightRotate(Node_t a) { ?b = a->left; ?a->left = b->right; ?b->right = a; ?a->height = Max(Height(a->left), Height(a->right)); ?b->height = Max(Height(b->left), Height(b->right)); ?return b; }

3.2 RR

RR情況需要左旋解決,如下圖所示:

代碼為:

1 2 3 4 5 6 7 8 Node_t LeftRotate(Node_t a) { ?b = a->right; ?a->right = b->left; ?b->left = a; ?a->height = Max(Height(a->left), Height(a->right)); ?b->height = Max(Height(b->left), Height(b->right)); ?return b; }

3.3 LR

LR情況需要左右(先B左旋轉(zhuǎn),后A右旋轉(zhuǎn))旋解決,如下圖所示:

代碼為:

1 2 3 4 Node_t LeftRightRotate(Node_t a) { ?a->left = LeftRotate(a->left); ?return RightRotate(a); }

3.4 RL

RL情況需要右左旋解決(先B右旋轉(zhuǎn),后A左旋轉(zhuǎn)),如下圖所示:

代碼為:

1 2 3 4 Node_t RightLeftRotate(Node_t a) { ?a->right = RightRotate(a->right); ?return LeftRotate(a); }

4. AVL數(shù)的插入和刪除操作

(1) 插入操作:實(shí)際上就是在不同情況下采用不同的旋轉(zhuǎn)方式調(diào)整整棵樹,具體代碼如下:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 Node_t Insert(Type x, Tree t) { ?if(t == NULL) { ???t = NewNode(x); ?} else if(x < t->data) { ???t->left = Insert(t->left); ???if(Height(t->left) - Height(t->right) == 2) { ????if(x < t->left->data) { ?????t = RightRotate(t); ????} else { ?????t = LeftRightRotate(t); ????} ??} ?} else { ???t->right = Insert(t->right); ???if(Height(t->right) - Height(t->left) == 2) { ????if(x > t->right->data) { ?????t = LeftRotate(t); ????} else { ?????t = RightLeftRotate(t); ????} ??} ?} ?t->height = Max(Height(t->left), Height(t->right)) + 1; ?return t; }

(2) 刪除操作:首先定位要?jiǎng)h除的節(jié)點(diǎn),然后用該節(jié)點(diǎn)的右孩子的最左孩子替換該節(jié)點(diǎn),并重新調(diào)整以該節(jié)點(diǎn)為根的子樹為AVL樹,具體調(diào)整方法跟插入數(shù)據(jù)類似,代碼如下:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 Node_t Delete(Type x, Tree t) { ?if(t == NULL) return NULL; ?if(t->data == x) { ??if(t->right == NULL) { ???Node_t temp = t; ???t = t->left; ???free(temp); ??} else { ???Node_t head = t->right; ???while(head->left) { ????head = head->left; ???} ???t->data = head->data; //just copy data ???t->right = Delete(t->data, t->right); ???t->height = Max(Height(t->left), Height(t->right)) + 1; ??} ??return t; ?} else if(t->data < x) { ??Delete(x, t->right); ??if(t->right) Rotate(x, t->right); ?} else { ??Delete(x, t->left); ??if(t->left) Rotate(x, t->left); ?} ?if(t) Rotate(x, t); }

5. 總結(jié)

AVL樹是最早的自平衡二叉樹,相比于后來出現(xiàn)的平衡二叉樹(紅黑樹,treap,splay樹)而言,它現(xiàn)在應(yīng)用較少,但研究AVL樹對(duì)于了解后面出現(xiàn)的常用平衡二叉樹具有重要意義。

6. 參考資料

(1) 數(shù)據(jù)結(jié)構(gòu)(C語言版) 嚴(yán)蔚敏,吳偉民著

(2)?http://zh.wikipedia.org/wiki/AVL%E6%A0%91

(3)http://www.cppblog.com/goodwin/archive/2011/08/08/152797.html

(4)http://www.asiteof.me/2010/06/avl/

———————————————————————————————-

更多關(guān)于數(shù)據(jù)結(jié)構(gòu)和算法的介紹,請(qǐng)查看:數(shù)據(jù)結(jié)構(gòu)與算法匯總

———————————————————————————————-

原創(chuàng)文章,轉(zhuǎn)載請(qǐng)注明:?轉(zhuǎn)載自董的博客

本文鏈接地址:?http://dongxicheng.org/structure/avl/

總結(jié)

以上是生活随笔為你收集整理的数据结构之AVL树的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。