免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: orangetouch

C实现的一个avl树 [复制链接]

论坛徽章:
0
发表于 2010-12-18 15:21 |显示全部楼层
下载下来学习一下, 谢谢分享

论坛徽章:
0
发表于 2010-12-18 23:34 |显示全部楼层
本帖最后由 zhousiyv 于 2010-12-19 00:20 编辑

GNU有libavl,可以同时对比下,另外,建议楼主写这种示例代码时不要封装(比如内存啥的),
让大家理解、修改起来容易点。

这里也有一个实现。


关于删除,我记得的是跟一般的BST一样找到待删除点X(直接前驱)后,交换数值,然后从X向根回溯,每一步调整结点的平衡因子,
如果本来是0(左右等高),改变为1或-1时,就停止回溯,如果不是就继续向上,如果出现-2或者2的平衡因子需要进行旋转,旋转情况分三种,插入时,如果是L形旋转,只需要分左结点平衡因子是1还是-1两种,分别对应LL和LR,删除时多一种,就是支点平衡因子是0的情况,

论坛徽章:
0
发表于 2013-10-08 07:46 |显示全部楼层
aaaaaaaaaaaaaaaaaa
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP