《数据结构与算法之美》学习笔记

散列表中

2020-05-27  本文已影响0人  TomGui

如何设计散列函数

装载因子过大了怎么办?

装载因子阈值的设置要权衡时间、空间复杂度。如果内存空间不紧张,对执行效率要求很高,可以降低负载因子的阈值;相反,如果内存空间紧张,对执行效率要求又不高,可以增加负载因子的值,甚至可以大于 1。

如何避免低效地扩容?

大部分情况下,动态扩容的散列表插入一个数据都很快,但是在特殊情况下,当装载因子已经到达阈值,需要先进行扩容,再插入数据。这个时候,插入数据就会变得很慢,甚至会无法接受。

如何选择冲突解决方法?

1. 开放寻址法

当数据量比较小、装载因子小的时候,适合采用开放寻址法。这也是Java 中的ThreadLocalMap使用开放寻址法解决散列冲突的原因。

2. 链表法

基于链表的散列冲突处理方法比较适合存储大对象、大数据量的散列表,而且,比起开放寻址法,它更加灵活,支持更多的优化策略,比如用红黑树代替链表。

工业级的散列表应该具有哪些特性?

如何实现这样一个散列表呢?

上一篇下一篇

猜你喜欢

热点阅读