哈希表
2019-02-14 本文已影响1人
952625a28d0d
映射(Map) 和 集合(Set)
-
哈希表(HashTable)、哈希函数(Hash Function)、哈希碰撞(Collisions)
-
Map & Set
-
HashMap、HashSet、TreeMap、TreeSet
-
HashTable
image.png
-
Coliisions
image.png
data:image/s3,"s3://crabby-images/2a382/2a3820603a669877b3a533ab2bfd080d43561fe8" alt=""
- Set实现是用树或者二叉树,查找起来比List的效率要高。
data:image/s3,"s3://crabby-images/97771/97771bd3cb5311eee900ddc00f359e8845895eb9" alt=""
-
HashMap、HashSet 实现是用数组、链表形式,而TreeMap、TreeSet实现是用二叉树的形式。那么HashMap的查找的时间复杂度是O(1),而TreeMap查找的时间复杂度是log n的时间复杂度
-
前者是乱序排列,后者是有序排列。
-
如果对时间复杂度要求很高的情况下,尽量使用HashMap或者HashSet,但如果要求使用一种相对有序的方式来储存的情况下,就要使用TreeMap或者TreeSet。
最佳实践
data:image/s3,"s3://crabby-images/2e240/2e24042a92c2c4087d68037ebdd156f2383fb340" alt=""
最后贴上不同数据结构的时间复杂度
data:image/s3,"s3://crabby-images/c4abd/c4abdfcd8fb35e6c061d77a73836ec7693e3f9da" alt=""