User Tools

Site Tools


hash_tables

Hash Table

Return to Data Structures

In computing, a hash table, also called hash map, is a data structure that implements an associative array or dictionary. It is an abstract data type that maps keys to value (Unique key to Value (computer science))1)

A hash table uses a hash function to compute an index, also called a hash code, into an array of buckets or slots, from which the desired value can be found. During lookup, the key is hashed and the resulting hash indicates where the corresponding value is stored.

Ideally, the hashing function will assign each key to a unique bucket, but most hash table designs employ an imperfect hash function, which might cause hash collisions where the hash function generates the same index for more than one key. Such collisions are typically accommodated in some way.

In a well-dimensioned hash table, the average time complexity for each hash lookup is independent of the number of elements stored in the table. Many hash table designs also allow arbitrary insertions and deletions of name–value pair (key–value pair, at amortized (amortized analysis) constant average cost per operation.2) 3) 4)

Hashing is an example of a space-time tradeoff. If computer memory is infinite, the entire key can be used directly as an index to locate its value with a single memory access. On the other hand, if infinite time is available, values can be stored without regard for their keys, and a binary search or linear search can be used to retrieve the element.

In many situations, hash tables turn out to be on average more efficient than search trees or any other table (computing) lookup structure. For this reason, they are widely used in many kinds of computer software, particularly for associative arrays, database indexing, caches, and sets (set (abstract data type).

Hash table


© 1994 - 2024 Cloud Monk Losang Jinpa or Fair Use. Disclaimers

SYI LU SENG E MU CHYWE YE. NAN. WEI LA YE. WEI LA YE. SA WA HE.


hash_tables.txt · Last modified: 2024/04/28 03:44 (external edit)