右旋

右旋结果:将该节点变成其左孩子的右孩子
右旋源码如下:

 /** From CLR */
    private void rotateRight(Entry<K,V> p) {
		//右旋前提,p和l都存在
        if (p != null) {
            Entry<K,V> l = p.left;		
---------------------------------------------------------------------------------------------------------------------------
   		  // ①: p的左孩子指向l的右孩子
          p.left = l.right;
  		 //如果l的右孩子存在,将l的右孩子的parent指向p,l的parent指向p的parent
            if (l.right != null), l.right.parent = p;
----------------------------------------------------------------------------------------------------------------------------
           //②:l的parent指向p的parent 
 		    l.parent = p.parent;
  		   //如果p的parent为空,l变成root节点
            if (p.parent == null)
                root = l;
			//p的parent不为空,先判断p如果是p的parent得到右孩子,将p的parent的右孩子指向l
            else if (p.parent.right == p)
                p.parent.right = l;
			//p如果是p的parent得到左孩子,将p的parent的左孩子指向l
            else p.parent.left = l;
			//l的右孩子指向p
---------------------------------------------------------------------------------------------------------------------------
  		    //③:将p变成l的右孩子
            l.right = p;
			//p的parent指向l
            p.parent = l;
			//至此p变成了它左孩子l的右孩子完成右旋
        }
    }

过程步骤分析:

① p.l–>l.r
若l.r存在 l.r.p–>p
②l.p–>p.p
若p.p不存在,l–>root
若p.p存在且p.p.r=p,p.p.r–>l
若p.p存在且p.p.l=p,p.p.l–>l
③将p变成l的右孩子
l.r–>p
p.p–>l

下图是p.p存在且p为p.p的左孩子,且l.r存在的情况
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值