怎么用Java哈希桶方式解决哈希冲突
发表于:2024-11-25 作者:千家信息网编辑
千家信息网最后更新 2024年11月25日,这篇文章主要介绍了怎么用Java哈希桶方式解决哈希冲突的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么用Java哈希桶方式解决哈希冲突文章都会有所收获,下面我们一起来看
千家信息网最后更新 2024年11月25日怎么用Java哈希桶方式解决哈希冲突
这篇文章主要介绍了怎么用Java哈希桶方式解决哈希冲突的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么用Java哈希桶方式解决哈希冲突文章都会有所收获,下面我们一起来看看吧。
一. 实现形式一(键值对只能为整数)
我们可以先实现一个比较简单的哈希表,使用java中解决哈希冲突的方法,即哈希桶(开散列)方式实现,其中注意:
可以使用内部类方式定义节点
负载因子默认为0.75
因为我们使用的是哈希桶方式解决哈希冲突,所以在我们扩容成功之后,原来桶中的数据得重新哈希计算出新的位置,不然就和原来桶中的数据的位置不一样了
相关代码如下
public class HashBucket { static class Node {//使用内部类方式定义节点 public int key; public int val; public Node next; public Node(int key, int val) { this.key = key; this.val = val; } } private Node[] array; public int usedSize; public HashBucket() { this.array = new Node[10]; this.usedSize = 0; } public void put(int key,int val) {//存放数据 //1、确定下标 int index = key % this.array.length; //2、遍历这个下标的链表 Node cur = array[index]; while (cur != null) { //更新val if(cur.key == key) { cur.val = val; return; } cur = cur.next; } //3、cur == null 当前数组下标的链表中没有key Node node = new Node(key,val); node.next = array[index]; array[index] = node; this.usedSize++; //4、判断当前有没有超过负载因子 if(loadFactor() >= 0.75) {//负载因子我们认为0.75 //扩容 resize(); } } public int get(int key) {//取出数据 //以什么方式存储的 那就以什么方式取 int index = key % this.array.length; Node cur = array[index]; while (cur != null) { if(cur.key == key) { return cur.val; } cur = cur.next; } return -1; } public double loadFactor() {//计算负载因子 return this.usedSize*1.0 / this.array.length; } public void resize() {//扩容函数 //自己创建新的2倍数组 Node[] newArray = new Node[2*this.array.length]; //遍历原来的哈希桶 //最外层循环 控制数组下标 for (int i = 0; i < this.array.length; i++) { Node cur = array[i]; Node curNext = null; while (cur != null) { //记录cur.next curNext = cur.next; //在新的数组里面的下标 int index = cur.key % newArray.length; //进行头插法 cur.next = newArray[index]; newArray[index] = cur; cur = curNext; } } this.array = newArray; }
二. 实现方式二(改进版)
上面我们实现的哈希表中的键值对只能存放整型数据,但若是比较复杂的类型,例如字符串,对象等等,此时就需要用到泛型了。其中注意:
同样可以使用内部类方式定义节点类型
使用泛型
将泛型转换成整数时要用到
hashCode
方法利用对象哈希值确定下标,为了防止哈希值太大,应该让其%数组的长度
遍历数组下标时,利用equals方法比较key是否相同
存放自定义的数据类型时,一定要重写
hashcode
和equals方法
相关代码如下
class Person { public String id; public Person(String id) { this.id = id; } @Override public String toString() { return "Person{" + "id='" + id + '\'' + '}'; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Person person = (Person) o; return Objects.equals(id, person.id); } @Override public int hashCode() { return Objects.hash(id); }}public class HashBuck2{ static class Node { public K key; public V val; public Node next; public Node(K key,V val) { this.key = key; this.val = val; } } public Node [] array = (Node []) new Node[10]; public int usedSize; public void put(K key,V val) { //通过hashcode方法定位数组的下标 int hash = key.hashCode(); int index = hash % this.array.length; Node cur = array[index]; while (cur != null) { //equals 起的作用是遍历当前数组下标的key是否相同 if(cur.key.equals(key)) { cur.val = val; } cur = cur.next; } Node node = new Node<>(key,val); node.next = array[index]; array[index] = node; this.usedSize++; } public V get(K key) { int hash = key.hashCode(); int index = hash % this.array.length; Node cur= array[index]; while (cur != null) { if(cur.key.equals(key)) { return cur.val; } cur = cur.next; } return null; }
关于"怎么用Java哈希桶方式解决哈希冲突"这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对"怎么用Java哈希桶方式解决哈希冲突"知识都有一定的了解,大家如果还想学习更多知识,欢迎关注行业资讯频道。
哈希
方式
下标
数组
冲突
数据
方法
因子
知识
类型
节点
相同
代码
位置
内容
对象
整数
篇文章
复杂
成功
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
deepin服务器版
表格智能填充数据库
奥迪a4l互联网科技
东莞万力达网络技术有限公司
数据库 存电话号码
鄂尔多斯网络安全知识大赛
软件开发外包验收单
常州dell服务器维修
faers数据库药物名称
php 调用js 更新数据库
数据库和es数据同步
服务器装多个wordpress
什么服务器最厉害
江苏工控软件开发有用吗
网络安全法法制讲座
黑魂三角色捏脸数据库
肇庆pc软件开发联系方式
全国网络安全形势分析
access数据库做资料
大学数据库实验总结200字
桐庐软件开发公司
网络安全等级考试难吗
徐州现代软件开发配置
深圳小鹅网络技术鲍春健
计算机网络技术自学看什么书
互联网公司用什么软件开发
蓝谷网络技术有限公司长沙
网络安全的汽车公司
足球对冲软件开发
网络安全法第22条案例