android hashmap remove删不掉_HasMap之remove详解(一)

1. 导读

本期分享的是本人对于HashMap::remove的理解以及红黑树删除知识准备, 主要是围绕:

.1 removeNode;

.2 红黑树删除节点;

这两块内容来展开的;

2. HashMap::removeNode

我们先来看下HashMap::remove(JAVA8)的主流程:

HashMap::removeNode是分了两步: 找节点和删除节点; .1 先根据key找到对应的节点, 非首节点时, 需要判断是红黑树还是链表; .2 如果节点不存在, 返回null; .3 找到对应节点后, 如果是红黑树, 调用红黑树的removeTreeNode方法删除节点; .4 如果是链表, 判断是否为首节点, 如果是首节点, 直接移除首节点即可; .5 非首节点时, 需要将x(目标节点)的父节点p的子节点更改为x的子节点; .6 返回删除的节点; HashMap::removeNode当节点存在时, 会返回删除的节点, 不存在时返回null;

3. 红黑树删除节点

链表的节点删除还是很简单的, 下面重点关注下红黑树的节点删除;在进入主题前, 我们先来看下红黑树节点删除的预备知识:

首先因为红黑树是有序的, 那么当我们要删除8节点时, 怎么办?

有两种方法:

.1 找到左子树中最大节点, 用6替换掉8, 这种方式叫找前驱;

.2 找到右子树中最小节点, 用11替换掉8, 这种方式叫找后继;

.3 如果左右子树都为空, 那么直接删除即可;

为什么要使用找前驱(后继)来替换原有节点再删除呢?

因为如果直接删除最差情况是该节点最多有两个子节点, 但是使用找前驱替换, 可以把判断两个字节点的情况转换为判断至多一个子节点的情况; 下面我们用前驱法详细说明下红黑树节点删除的过程(注

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值