 
- Graph Theory - Home
- Graph Theory - Introduction
- Graph Theory - History
- Graph Theory - Fundamentals
- Graph Theory - Applications
- Types of Graphs
- Graph Theory - Types of Graphs
- Graph Theory - Simple Graphs
- Graph Theory - Multi-graphs
- Graph Theory - Directed Graphs
- Graph Theory - Weighted Graphs
- Graph Theory - Bipartite Graphs
- Graph Theory - Complete Graphs
- Graph Theory - Subgraphs
- Graph Theory - Trees
- Graph Theory - Forests
- Graph Theory - Planar Graphs
- Graph Theory - Hypergraphs
- Graph Theory - Infinite Graphs
- Graph Theory - Random Graphs
- Graph Representation
- Graph Theory - Graph Representation
- Graph Theory - Adjacency Matrix
- Graph Theory - Adjacency List
- Graph Theory - Incidence Matrix
- Graph Theory - Edge List
- Graph Theory - Compact Representation
- Graph Theory - Incidence Structure
- Graph Theory - Matrix-Tree Theorem
- Graph Properties
- Graph Theory - Basic Properties
- Graph Theory - Coverings
- Graph Theory - Matchings
- Graph Theory - Independent Sets
- Graph Theory - Traversability
- Graph Theory Connectivity
- Graph Theory - Connectivity
- Graph Theory - Vertex Connectivity
- Graph Theory - Edge Connectivity
- Graph Theory - k-Connected Graphs
- Graph Theory - 2-Vertex-Connected Graphs
- Graph Theory - 2-Edge-Connected Graphs
- Graph Theory - Strongly Connected Graphs
- Graph Theory - Weakly Connected Graphs
- Graph Theory - Connectivity in Planar Graphs
- Graph Theory - Connectivity in Dynamic Graphs
- Special Graphs
- Graph Theory - Regular Graphs
- Graph Theory - Complete Bipartite Graphs
- Graph Theory - Chordal Graphs
- Graph Theory - Line Graphs
- Graph Theory - Complement Graphs
- Graph Theory - Graph Products
- Graph Theory - Petersen Graph
- Graph Theory - Cayley Graphs
- Graph Theory - De Bruijn Graphs
- Graph Algorithms
- Graph Theory - Graph Algorithms
- Graph Theory - Breadth-First Search
- Graph Theory - Depth-First Search (DFS)
- Graph Theory - Dijkstra's Algorithm
- Graph Theory - Bellman-Ford Algorithm
- Graph Theory - Floyd-Warshall Algorithm
- Graph Theory - Johnson's Algorithm
- Graph Theory - A* Search Algorithm
- Graph Theory - Kruskal's Algorithm
- Graph Theory - Prim's Algorithm
- Graph Theory - Borůvka's Algorithm
- Graph Theory - Ford-Fulkerson Algorithm
- Graph Theory - Edmonds-Karp Algorithm
- Graph Theory - Push-Relabel Algorithm
- Graph Theory - Dinic's Algorithm
- Graph Theory - Hopcroft-Karp Algorithm
- Graph Theory - Tarjan's Algorithm
- Graph Theory - Kosaraju's Algorithm
- Graph Theory - Karger's Algorithm
- Graph Coloring
- Graph Theory - Coloring
- Graph Theory - Edge Coloring
- Graph Theory - Total Coloring
- Graph Theory - Greedy Coloring
- Graph Theory - Four Color Theorem
- Graph Theory - Coloring Bipartite Graphs
- Graph Theory - List Coloring
- Advanced Topics of Graph Theory
- Graph Theory - Chromatic Number
- Graph Theory - Chromatic Polynomial
- Graph Theory - Graph Labeling
- Graph Theory - Planarity & Kuratowski's Theorem
- Graph Theory - Planarity Testing Algorithms
- Graph Theory - Graph Embedding
- Graph Theory - Graph Minors
- Graph Theory - Isomorphism
- Spectral Graph Theory
- Graph Theory - Graph Laplacians
- Graph Theory - Cheeger's Inequality
- Graph Theory - Graph Clustering
- Graph Theory - Graph Partitioning
- Graph Theory - Tree Decomposition
- Graph Theory - Treewidth
- Graph Theory - Branchwidth
- Graph Theory - Graph Drawings
- Graph Theory - Force-Directed Methods
- Graph Theory - Layered Graph Drawing
- Graph Theory - Orthogonal Graph Drawing
- Graph Theory - Examples
- Computational Complexity of Graph
- Graph Theory - Time Complexity
- Graph Theory - Space Complexity
- Graph Theory - NP-Complete Problems
- Graph Theory - Approximation Algorithms
- Graph Theory - Parallel & Distributed Algorithms
- Graph Theory - Algorithm Optimization
- Graphs in Computer Science
- Graph Theory - Data Structures for Graphs
- Graph Theory - Graph Implementations
- Graph Theory - Graph Databases
- Graph Theory - Query Languages
- Graph Algorithms in Machine Learning
- Graph Neural Networks
- Graph Theory - Link Prediction
- Graph-Based Clustering
- Graph Theory - PageRank Algorithm
- Graph Theory - HITS Algorithm
- Graph Theory - Social Network Analysis
- Graph Theory - Centrality Measures
- Graph Theory - Community Detection
- Graph Theory - Influence Maximization
- Graph Theory - Graph Compression
- Graph Theory Real-World Applications
- Graph Theory - Network Routing
- Graph Theory - Traffic Flow
- Graph Theory - Web Crawling Data Structures
- Graph Theory - Computer Vision
- Graph Theory - Recommendation Systems
- Graph Theory - Biological Networks
- Graph Theory - Social Networks
- Graph Theory - Smart Grids
- Graph Theory - Telecommunications
- Graph Theory - Knowledge Graphs
- Graph Theory - Game Theory
- Graph Theory - Urban Planning
- Graph Theory Useful Resources
- Graph Theory - Quick Guide
- Graph Theory - Useful Resources
- Graph Theory - Discussion
Graph Theory - Adjacency List
Adjacency List
Unlike the adjacency matrix, which stores a value for every possible edge in the graph, the adjacency list stores only the edges that exist.
An adjacency list is a way of representing a graph where each vertex has a list of other vertices it is directly connected to. This representation is efficient in terms of space, especially for sparse graphs, as it only stores the edges that actually exist in the graph.
 
The adjacency lists for this graph is as follows −
Adjacency List Representation: Node 0: [2, 4, 5] Node 1: [4] Node 2: [0, 3, 5] Node 3: [2, 4] Node 4: [0, 1, 3, 5] Node 5: [0, 2, 4]
Structure of the Adjacency List
The adjacency list consists of an array (or a similar data structure) of lists, where each list contains the neighbors of a particular vertex. In a directed graph, the list will only contain outgoing edges. In an undirected graph, the list will contain both incoming and outgoing edges.
Each vertex v in the graph has a corresponding list, and each element in the list represents an edge connecting v to another vertex u. In the case of a weighted graph, each element can store both the adjacent vertex and the weight of the edge.
Adjacency List for Undirected Graphs
For an undirected graph, if there is an edge between vertex v and vertex u, both vertice's lists will contain each other. In other words, an edge between v and u is represented twice in the adjacency list.
Consider an undirected graph with 3 vertices: V = {A, B, C} and edges {A-B, A-C}. The adjacency list representation would look like this −
A -> B, C B -> A C -> A
Adjacency List for Directed Graphs
For a directed graph, if there is an edge from vertex v to vertex u, only vertex v's list will contain u, and u's list will not contain v unless there is a separate edge from u to v.
Consider a directed graph with 3 vertices: V = {A, B, C} and edges {A->B, A->C}. The adjacency list representation would look like this −
A -> B, C B -> C ->
Adjacency List for Weighted Graphs
For a weighted graph, the adjacency list stores not only the adjacent vertex but also the weight of the edge connecting them. Each element in the list becomes a pair of vertex and weight.
Consider a weighted graph with 3 vertices: V = {A, B, C} and edges {A-B: 5, A-C: 3}. The adjacency list representation for this weighted graph would look like this −
A -> (B, 5), (C, 3) B -> (A, 5) C -> (A, 3)
Properties of the Adjacency List
The adjacency list has several major properties that make it useful for representing graphs. Following are some of its major properties −
Space Complexity
The space complexity of the adjacency list is O(V + E), where V is the number of vertices and E is the number of edges in the graph.
This makes the adjacency list much more space-efficient than the adjacency matrix, especially for sparse graphs, where the number of edges is much smaller than the number of possible edges.
Edge Lookup
To check whether there is an edge between two vertices v and u, we must traverse the list of adjacent vertices for v and check for u.
This has a time complexity of O(d(v)), where d(v) is the degree of vertex v (the number of edges connected to it). In the worst case, the lookup time is linear with respect to the number of neighbors.
Edge Insertion
Inserting an edge into the adjacency list can be done in O(1) time, as it involves adding a vertex to a list of adjacent vertices. If the graph is weighted, it involves adding a pair of the adjacent vertex and the weight.
Efficient for Sparse Graphs
The adjacency list is especially efficient for sparse graphs, where the number of edges E is much smaller than the number of possible edges V(V-1)/2 in an undirected graph (or V(V-1) in a directed graph).
Since it only stores existing edges, it avoids wasting memory on non-existent edges, unlike the adjacency matrix.
Traversal Complexity
Traversing an adjacency list involves iterating over the neighbors of each vertex. The time complexity for traversing the entire graph is O(V + E), as we visit each vertex and each edge once. This is more efficient than the adjacency matrix, which has a time complexity of O(V) for traversal.
Applications of the Adjacency List
The adjacency list is commonly used in various graph algorithms and applications −
Graph Traversal
Graph traversal algorithms like Depth-First Search (DFS) and Breadth-First Search (BFS) work efficiently with adjacency lists. In these algorithms, we explore the neighbors of each vertex, and the adjacency list provides easy access to the adjacent vertices.
Shortest Path Algorithms
Algorithms like Dijkstra's and Bellman-Ford use the adjacency list for finding the shortest path between vertices. The adjacency list helps to store the graph structure and allows quick access to neighboring vertices during the algorithm's execution.
Topological Sorting
In directed acyclic graphs (DAGs), topological sorting can be performed with the adjacency list. The list helps to quickly access neighbors and maintain the required order of vertices during sorting.
Minimum Spanning Tree Algorithms
Algorithms like Prim's and Kruskal's use the adjacency list to find the minimum spanning tree of a graph. The adjacency list allows easy access to neighboring vertices.
Adjacency List: Pros and Cons
The adjacency list has several advantages and disadvantages depending on the graph's structure and the algorithms being applied −
Advantages
Following are the advantages of adjacency list −
- Space Efficiency: The adjacency list is highly space-efficient, especially for sparse graphs, as it stores only the existing edges.
- Efficient for Sparse Graphs: It is ideal for sparse graphs, where the number of edges is much smaller than the number of vertices.
- Fast Edge Insertion: Adding an edge to the graph is efficient, with constant-time insertion.
- Efficient for Traversal: Traversing the graph, particularly in DFS or BFS, is quick and efficient with the adjacency list.
Disadvantages
Following are the disadvantages of adjacency list −
- Slow Edge Lookup: Checking for the existence of an edge between two vertices can take time proportional to the number of neighbors, making it slower than the adjacency matrix for certain operations.
- Less Efficient for Dense Graphs: For dense graphs where the number of edges is close to the number of vertices squared, the adjacency list can become less efficient compared to the adjacency matrix.
Adjacency List Alternatives
While the adjacency list is the preferred representation for sparse graphs, several optimizations and alternative representations can improve performance in different situations −
Compressed Adjacency List
In situations where the graph has many vertices but relatively few edges, a compressed adjacency list can be used to reduce memory usage by only storing the adjacency information in a more compact form.
Edge List
For very sparse graphs or when the graph is not frequently updated, an edge list can be used as a simple and efficient way to represent the graph. Each edge is stored as a pair of vertices, which can be very memory efficient.
Adjacency Matrix for Dense Graphs
For dense graphs, where the number of edges is close to the maximum possible number of edges, the adjacency matrix can sometimes be more efficient, as it allows constant-time edge lookups.