平衡二叉排序树算法 细节问题?
来源:互联网 发布:淘宝购物折扣软件 编辑:程序博客网 时间:2024/04/29 17:09
最近公司要我做一个演讲,其实就是一个交流会,题目是红黑树。谁叫我是新手呢,得准备啊,看了好久,都不懂,哎,先看看平衡二叉树
吧。
我先看了下平衡二叉树的算法,总结如下。
平衡二叉树的目的就是为了解决查找时的时间效率问题,尽量是查询的时间效率保持在log n
需要平衡的四种情况:
1、 左-左-左
2、 左-右-左
3、 右-右-右
4、 右-右-左
如下图所示:
1、3只需要旋转一次,分别是右旋,左旋
2、4需要旋转两次,分别是先左旋再右旋,先右旋再左旋。
思想虽然简单,但是我始终看不懂LeftBalance函数中case RH: 中的
switch(rd->bf) //修改*T及其左孩子的平衡因子
{
case LH:T->bf = RH; lc->bf = EH; break;
case EH:T->bf = lc->bf = EH; break;
ase RH:T->bf = EH; lc->bf = LH; break;
}
这段代码,我觉得rd->bf始终都是等于EH的,也就是0,
下面的程序我把这段隐掉了,然后将switch语句用T->bf = lc->bf = EH;替换了。
类似的在RightBalance中,同样的我也做了同样的操作。
经测试,添加操作照样能够正常工作,难道是测试的例子太少了吗?希望哪位大侠能够解答,谢谢。
附上源代码。
- 平衡二叉排序树算法 细节问题?
- 二叉排序树、二叉平衡树算法
- 平衡二叉排序树的各种算法
- 平衡二叉排序树算法 四种情况详解
- 平衡二叉排序树
- 平衡二叉排序树
- 平衡二叉排序树
- 二叉排序树和平衡二叉排序树
- 数据结构与算法问题 二叉排序树
- 数据结构 平衡二叉排序树
- 二叉排序树、平衡树、红黑树
- 二叉排序树 平衡二叉树
- 平衡二叉排序树(AVL)
- 二叉排序树的旋转平衡
- 二叉排序树、平衡树、红黑树
- 二叉排序树与平衡二叉排序树的转化
- 二叉排序树算法
- 算法---二叉排序树
- 堆(heap)和堆栈(stack)有什么区别
- 堆(heap)和堆栈(stack)有什么区别
- access中使用“存储过程”
- 为使用mysql而配置codeblocks工程
- asp.net中实现DetailsView控件下的两个DropDownList级连变动
- 平衡二叉排序树算法 细节问题?
- [Android]应用程序无SDCard安装APK
- 子衿的事(33)
- 如水女人与似刚男人
- Root权限 安卓的担忧还是喜?
- PHP - phpini设置时区
- POS消费机C井例子代码(4)
- Struts2 mysql数据库的备份与还原
- 读取Property乱码