java - 伸展树的展开的理解
黄舟
黄舟 2017-04-18 09:51:27
[Java讨论组]

java实现伸展树

中的splay(Comparable key)方法,第198行:

l.right = t;           /* link left */
l = t;
t = t.right;

不能理解l=t;前面的l.right = t不就是被覆盖掉了吗?

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全部回复(2)
ringa_lee

这里只是l和t这两个引用在移动:

  1. 假设l原来指向节点a,a的左节点和右节点分别是a1和a2。t原来指向节点b,b的左节点和右节点分别是b1和b2

  2. l.right = t,l是指向a的,这个操作也就是a的右节点变成了b,l依然指向a,t依然指向b

  3. l = t,l改成指向b,t没变也指向b

  4. t = t.right,t原来指向b,那么现在改成指向b的右节点,即b2

这么一通下来后a的左节点没变依然是a1,右节点变成b,而a2已经和a断开了。相当于把b这课子树移到了a的右边。
同时l和t的指向改变了,l指向b,t指向b2

ringa_lee


l = t;
看成:
l = l.right;
指针的移动,方便一次迭代.

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号