hashMap索引原理

平日里面经常使用map这种数据结构,令人称奇的是他的访问速度为什么那么快?为什么可以通过key以接近O(1)的速度查找?

一、基础数据结构特点分析

1.1数组

查找的时间复杂度为O(1)

插入时间复杂度为O(n)

1.2链表

查找的时间复杂度为O(n)

插入时间复杂度为O(1)

1.3红黑树

一种平衡树,能以较低的时间复杂度进行搜索、添加和查找操作O(logn)

可以优化节点查找速度

所以如果我们能找到一种,通过数组进行范围筛选,通过链表对数据进行增删的数据结构来存储数据,那么就能够获得较快的查询速率

二、hashMap基本实现原理

2.1hash过程

将这个数据节点进行hasCode操作,获取一个hash值

2.2hash定位

hash值对数组长度取模,获取一个模值,相同模值的数据节点挂载在同一个链表上

2.3查找

获取数据的时候就将该key转成hash,计算其模值,在对应的链表上面进行顺序查找

2.4hash冲突过多的优化

什么是hash冲突?:不同的key算出了相同的hash

解决方案1(Java采用)------链地址法:相同的hash值转到一个链表,链表长度大于8转换成红黑树,红黑树规模小于6退化成链表

特点:

(1)要减少hash冲突需要很大的散列,利用率不够大

(2)默认大小为16,超过就扩充一倍

解决方案2(Python采用)------开放寻址法:算出了相同的hash值就继续往下遍历寻找第一个找到的空hash值

特点:

(1)适用于负载不大的散列,负载过大会长时间找不到空hash

(2)负载超过一定阙值就扩容,而不是满了再扩容

相关推荐
ECT-OS-JiuHuaShan4 分钟前
渡劫代谢,好事多磨
数据库·人工智能·科技·学习·算法·生活
We་ct17 分钟前
LeetCode 64. 最小路径和:动态规划入门实战
开发语言·前端·算法·leetcode·typescript·动态规划
CoderCodingNo18 分钟前
【CSP】CSP-J 2019 江西真题 | 次大值 luogu-P5682 (适合GESP四、五级及以上考生练习)
开发语言·c++·算法
做cv的小昊26 分钟前
【TJU】应用统计学——第七周作业(4.2 多元线性回归分析、4.3 可化为线性回归的曲线回归、4.4 单因子方差分析)
线性代数·算法·数学建模·矩阵·回归·线性回归·概率论
被摘下的星星30 分钟前
子网de划分
网络·算法
Felven35 分钟前
A. Red Versus Blue
算法
꧁细听勿语情꧂1 小时前
向下调整算法,top - k 问题,链式结构二叉树,前中后序遍历
c语言·开发语言·数据结构·算法
水蓝烟雨1 小时前
3487. 删除后的最大子数组元素和
算法·leetcode·链表
LG.YDX2 小时前
笔试训练48天:最长无重复子数组
数据结构·算法
yong99902 小时前
基于灰狼算法优化支持向量回归(GWO-SVR)的混合算法
算法·数据挖掘·回归