堆 02 添加 & 上浮

void add(E e) - 向最大堆中添加元素

  • 从二叉树的角度看,向最大堆中添加元素就是接着在完全二叉树的下一个位置码上元素;
  • 从数据的角度看,就是在数组的最后添加一个元素;
  • 从堆的角度看,新添加的元素不能比它的父元素大,如果比它的父元素大,就涉及到上浮的动作;
// 向堆中添加元素
public void add(E e){
    data.addLast(e);
    siftUp(data.getSize() - 1);
}

void siftUp(int k) - 上浮新添加的元素

  • k是新添加的元素的索引;
  • 若果k > 0,并且其值大于其父节点的值:
    • 新添加的元素和其父元素交换位置;
    • 让游标k追到新添加的元素上浮后的位置;
private void siftUp(int k){
    while(k > 0 && data.get(parent(k)).compareTo(data.get(k)) < 0 ){
        data.swap(k, parent(k));
        k = parent(k);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值