Comparison of Graph Representations
Learn how adjacency matrices and adjacency lists compare.
We'll cover the following
After studying both adjacency matrices and adjacency lists, let’s see how they compare for common operations that we’ll perform in graph algorithms.
In most applications of graph algorithms, the set of nodes is constant. No nodes are added or removed over time. We can therefore focus on operations that work on the edge set .
Memory usage
The adjacency matrix stores at least one bit for every ordered pair of nodes . Since there are exactly such pairs, the memory footprint is .
The adjacency list representation needs to store one list for each node in the graph, which takes at least space. Additionally, every edge of the graph needs to be stored in one of the lists, taking up further space. The total memory requirements are thus .
In most cases, the adjacency list representation is more memory efficient, as it stores only the present edges, while the adjacency matrix also contains entries for all absent edges. The two representations are comparable only in dense graphs. Note that in a dense graph, the number of edges is close to the maximum number of edges (), so we have .
Operations on single edges
Let’s assume that we are given two nodes , and we want to perform an operation on the edge , for example:
- Test whether the edge exists.
- Add or remove the edge.
- Modify the edge’s weight.
Get hands-on with 1200+ tech skills courses.