1. Dynamic hash tables
- Author
-
Per-Åke Larson
- Subjects
General Computer Science ,Computer science ,Hash function ,Linear hashing ,Locality-sensitive hashing ,K-independent hashing ,Open addressing ,Pearson hashing ,Data_FILES ,Computer Science::Data Structures and Algorithms ,Consistent hashing ,Computer Science::Databases ,Computer Science::Cryptography and Security ,Binary tree ,Universal hashing ,Dynamic perfect hashing ,Linear probing ,2-choice hashing ,Hash table ,Hopscotch hashing ,Cuckoo hashing ,SUHA ,Locality preserving hashing ,Feature hashing ,Algorithm ,Extendible hashing ,Double hashing ,Tabulation hashing - Abstract
Linear hashing and spiral storage are two dynamic hashing schemes originally designed for external files. This paper shows how to adapt these two methods for hash tables stored in main memory. The necessary data structures and algorithms are described, the expected performance is analyzed mathematically, and actual execution times are obtained and compared with alternative techniques. Linear hashing is found to be both faster and easier to implement than spiral storage. Two alternative techniques are considered: a simple unbalanced binary tree and double hashing with periodic rehashing into a larger table. The retrieval time of linear hashing is similar to double hashing and substantially faster than a binary tree, except for very small trees. The loading times of double hashing (with periodic reorganization), a binary tree, and linear hashing are similar. Overall, linear hashing is a simple and efficient technique for applications where the cardinality of the key set is not known in advance.
- Published
- 1988
- Full Text
- View/download PDF