Motivation
Suppose we have an array:
data:image/s3,"s3://crabby-images/acfef/acfef9e46b8e68bce731170c99dc70fb12263e61" alt=""
And we want to store a bunch of elements in it:
$$ \text{cat}, \space \text{bat}, \space \text{tap}, \space \text{mad}, \text{dam}, \space \text{nap}, \space \text{pat} $$
What will we do?
Well, we most likely store them sequentially one after another.
data:image/s3,"s3://crabby-images/d37a0/d37a095ae8eef3d55063b4b6b85d29f9819616db" alt=""
Here, insertion is fast (constant time) and searching is slow (linear time).
We can get logarithmic-time search (via binary search) if we keep the data sorted but that means extra work for insertion (linear time).
data:image/s3,"s3://crabby-images/06997/06997f5662a73e7d3430566fcf650470f086e78f" alt=""
We could organize the data in a (balanced) binary search tree to get logarithmic-time insert/remove and find.
data:image/s3,"s3://crabby-images/9db67/9db67d9c09639a9f5fa8f2954f3070c84dd81a1f" alt=""
But is there any way to get constant time for all the core operations?
It turns out, there is a data structure that can do that! It is called a Hash Table.