Hash Maps: Introduction

Let’s understand the Hash Maps pattern, its real-world applications, and some problems we can solve with it.

Overview#

The hash map pattern is a method to store data. It aims to reduce the time taken to find and access values.

Hash maps store data in the form of key-value pairs. They are similar to arrays because array values are stored against numeric keys. These keys are known as indexes. We don’t get to pick the value of these keys as they are always sequential integers starting from 00. Therefore, if we want to find an element within an array and don’t know it’s index, we’ll have to search the entire array which, in the worst case, will take O(N)O(N) time.

On the contrary, hash maps allow us to have flexible keys. Each key is unique and is mapped against a value. Therefore, we can look up its value in O(1)O(1) time.

A practical application of using hash maps over arrays would be to lookup the marks of students. Had we used arrays, we would have to create the following two arrays:

  • names: This stores the names of the students.

  • marks: This stores the marks of the students.

We would have to make sure that the names and marks arrays store their values in the same order. This means if “John” is at index 4 in the names array, his marks should also be present at the same index in the marks array. This process is very tedious since we first have to make a lookup in the names array in O(N)O(N) time and then, using the corresponding index, perform another lookup in the marks array in O(1)O(1) time.

Using a hash map makes our life much easier. We can use the names of the students as keys, and their marks are the corresponding values. Now we only have to perform one lookup for the marks of a student in O(1)O(1) time.

The following illustration shows how values are inserted and accessed from a hash map in the above example:

Created with Fabric.js 3.6.6

1 of 7

Created with Fabric.js 3.6.6

2 of 7

Created with Fabric.js 3.6.6

3 of 7

Created with Fabric.js 3.6.6

4 of 7

Created with Fabric.js 3.6.6

5 of 7

Created with Fabric.js 3.6.6

6 of 7

Created with Fabric.js 3.6.6

7 of 7

Examples#

The following examples illustrate some problems that can be solved with this approach:

Created with Fabric.js 3.6.6

1 of 2

Created with Fabric.js 3.6.6

2 of 2

Does my problem match this pattern?#

  • Yes, if both these conditions are fulfilled:

    • When we require repeated fast access to data during the execution of the algorithm.
    • We need to store the relationship between two sets of data in order to compute the required result. This is achieved through the mechanism of a key-value pair, where we stored the hashed version of the key to enable fast look-ups.
  • No, if no useful relation can be established between two sets of data.

Real-world problems#

Many problems in the real world share the hash maps pattern. Let’s look at some examples.

  • Telecommunications: Implement a phone book with the name of the person as the key, and their number as the corresponding value.

  • E-commerce: Search for details of a product using its product ID as the key.

  • File system: When a user interacts with a file system, they see the file name and the path. The system uses a hash map to store the correspondence between the file name and its path.

Strategy time!#

Match the problems that can be solved using the hash map pattern.

Note: Select a problem in the left-hand column by clicking it, and then click one of the two options in the right-hand column.

Match The Answer
Select an option from the left-hand side

Find four elements aa, bb, cc and dd in an array such that a+b=c+da+b = c+d.

Explanation

Hash Maps

Detect a cycle in an undirected graph.

Explanation

Some other pattern

Rotate a linked list.

Explanation

Divide an array into pairs whose sum is divisible by 22.

Explanation

Isomorphic Strings