第三十四篇 玩转数据结构——哈希表(HashTable)
2024-10-08 10:32:48
1.. 整型哈希函数的设计
- 小范围正整数直接使用
- 小范围负整数整体进行偏移
- 大整数,通常做法是"模一个素数"
2.. 浮点型哈希函数的设计
- 转成整型进行处理
3.. 字符串哈希函数的设计
- 转成整型进行处理
- 简单变形优化
- 防止整型溢出优化
- 具体代码实现
4.. 复合类型哈希函数的设计
- 转成整型进行处理
5.. 哈希函数的设计原则
6.. 哈希冲突的处理
- 链地址法
- 开放地址法之线性探测
开放地址法之平方探测
- 开放地址法之二次哈希
7.. 哈希表的动态空间处理
8.. 实现哈希表的业务逻辑
import java.util.TreeMap; public class HashTable<K, V> { private final int[] capacity
= {53, 97, 193, 389, 769, 1543, 3079, 6151, 12289, 24593,
49157, 98317, 196613, 393241, 786433, 1572869, 3145739, 6291469, 12582917,
25165843, 50331653, 100663319, 201326611, 402653189, 805306457, 1610612741};
private static final int upperTol = 10;
private static final int lowerTol = 2;
private int capacityIndex = 0;
private TreeMap<K, V>[] hashTable;
private int M;
private int size; public HashTable() { this.M = capacity[capacityIndex];
this.size = 0;
hashTable = new TreeMap[M];
for (int i = 0; i < M; i++) {
hashTable[i] = new TreeMap<>();
}
} private int hash(K key) {
return key.hashCode() & 0x7fffffff % M;
} public void add(K key, V value) { TreeMap<K, V> map = hashTable[hash(key)]; if (map.containsKey(key)) {
map.put(key, value);
} else {
map.put(key, value);
size++;
if (size >= upperTol * M && capacityIndex + 1 < capacity.length) {
capacityIndex++;
resize(capacity[capacityIndex]);
}
}
} public V remove(K key) { TreeMap<K, V> map = hashTable[hash(key)]; V ret = null;
if (map.containsKey(key)) {
ret = map.remove(key);
size--;
if (size < lowerTol * M && capacityIndex - 1 >= 0) {
capacityIndex--;
resize(capacity[capacityIndex]);
}
}
return ret;
} public void set(K key, V value) { TreeMap<K, V> map = hashTable[hash(key)]; if (!map.containsKey(key)) {
throw new IllegalArgumentException(key + "doesn't exist.");
} else {
map.put(key, value);
}
} public boolean contains(K key) { return hashTable[hash(key)].containsKey(key);
} public V get(K key) { return hashTable[hash(key)].get(key);
} private void resize(int newM) { TreeMap<K, V>[] newHashTable = new TreeMap[newM];
for (int i = 0; i < newM; i++) {
newHashTable[i] = new TreeMap<>();
} int oldM = M;
M = newM;
for (int i = 0; i < oldM; i++) {
TreeMap<K, V> map = hashTable[i];
for (K key : map.keySet()) {
newHashTable[hash(key)].put(key, map.get(key));
}
} this.hashTable = newHashTable;
} }
最新文章
- 记录visual Studio使用过程中的两个问题
- 【Leafletjs】7.结合echart图表展示信息
- Panel扩展 圆角边框,弧形边框
- CSS2简写代码(优化)
- javaScript 设计模式系列之四:组合模式
- Android开发——BroadcastReceiver广播的使用
- iOS - UIView 动画
- AWS EC2实例Linux系统创建root用户并更改为root用户登录
- Java多线程——中断机制
- Busybox的syslogd认识与使用
- IDEA中Git的更新、提交、还原方法
- 官网下载的Struts 2解压后缺少xwork-core.jar文件
- iostat各字段的来源和真实含义
- fiddler学习总结--通过Fiddler模拟弱网进行测试
- CentOS6.8配置SonarQube Scanner配合SonarQube使用
- Linux中 Lua 访问Sql Server的配置方法
- C语言版 Hello World
- 优秀前端工程师必备:"; checkbox &; radio--单钩 &; 多钩 ";大比较:你是♂||♀ , 还是 ♂&;♀
- 第一章 数据库和SQL
- js里面setInterval和setTimeout相同点和区别
热门文章
- E11000 duplicate key error index: test.collection.$a.b_1 dup key: { : null } 报错记录
- 剑指offer-面试题9-用两个栈实现队列-栈和队列
- UVA12716-连续区间内反向寻因子法
- H5_0017:通过元素自定义属性值获取元素对象,并获取属性值
- Tiptop ERP 采购运费一键分摊
- Sql Server2008忘记sa登陆密码
- 402 WebEx会议教程二 —— 召开会议
- Codeforce 515A - Drazil and Date
- python xlrd 模块(获取Excel表中数据)
- ansible笔记(14):循环(一)