码迷,mamicode.com
首页 > 其他好文 > 详细

AVL树的旋转实现

时间:2015-06-09 21:33:58      阅读:136      评论:0      收藏:0      [点我收藏+]

标签:

AVL树:带有平衡条件的二叉查找树,即一棵AVL树是其每个节点的左子树和右子树的高度最多相差1的二叉查找树。一般通过Single Rotate和Double Rotate来保持AVL树的平衡。
AVL树的实现如下:

1) Single Rotate
技术分享

2)Double Rotate

技术分享

1) Single Rotate ( SingleRotateWithRight同理)

static Position SingleRotateWithLeft(Position K2)
{
Position K1;
K1=K2->Left;
K2->Left=K1->Right;
K1->Right=K2;
K2->Height=Max(Height(K2->Left),Height(K2->Right))+1;
K1->Height=Max(Height(K1->Left),Height(K1->Right))+1;
return K1;
}

2)Double Rotate(DoubleRotateWithRight同理)

static Position DoubleRotateWithLeft(Position K3)
{
K3->Left=SingleRotateWithRight(K3->Left);
return SingleRotateWithLeft(K3);
}

AVL树的旋转实现

标签:

原文地址:http://www.cnblogs.com/riden/p/4564432.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!