6. Topological Sort
The problem can be found at the following link: Question Link
Problem Description
Given a Directed Acyclic Graph (DAG) with V vertices (numbered from 0 to V-1) and E directed edges (represented as a 2D list where each edge is given as [u, v] indicating an edge from u to v), return a topological ordering of the vertices.
A topological sort of a DAG is a linear ordering of vertices such that for every directed edge u -> v, vertex u appears before vertex v in the ordering. Note: Since there can be multiple valid topological orders, you may return any one of them. The returned ordering is considered correct if for every directed edge u -> v, u comes before v.
Examples
Example 1:
Input:
V = 4, E = 3
edges = [[3, 0], [1, 0], [2, 0]]Output:
trueExplanation:
The output true denotes that the ordering is valid.
Few valid topological orders are:
- [3, 2, 1, 0] 
- [1, 2, 3, 0] 
- [2, 3, 1, 0] 
Example 2:
Input:
V = 6, E = 6
edges = [[1, 3], [2, 3], [4, 1], [4, 0], [5, 0], [5, 2]]Output:
trueExplanation:
The output true denotes that the returned ordering is valid.
Few valid topological orders for this graph are:
- [4, 5, 0, 1, 2, 3] 
- [5, 2, 4, 0, 1, 3] 
Constraints:
- 2 ≤ V ≤ 10³ 
- 1 ≤ E (edges.size()) ≤ (V * (V - 1)) / 2 
My Approach
Kahn’s Algorithm (BFS-based Topological Sort)
Algorithm Steps:
- Construct the Graph: - Build an adjacency list from the edge list. 
- Create an in-degree array to store the number of incoming edges for each vertex. 
 
- Initialize the Queue: - Push all vertices with in-degree 0 into a queue. 
 
- Process the Queue: - While the queue is not empty, pop a vertex and add it to the result list. 
- For each neighbor of the popped vertex, reduce its in-degree by 1. 
- If any neighbor's in-degree becomes 0, add it to the queue. 
 
- Final Check: - If the result list contains all vertices, the ordering is valid. 
 
Time and Auxiliary Space Complexity
- Expected Time Complexity: - O(V + E), as every vertex and edge is processed exactly once.
- Expected Auxiliary Space Complexity: - O(V + E), due to the storage required for the adjacency list, in-degree array, and queue.
Code (C++)
// ✅ Kahn’s Algorithm (BFS-based Topological Sort)
class Solution {
public:
    vector<int> topoSort(int V, vector<vector<int>>& edges) {
        vector<vector<int>> adj(V);
        vector<int> in(V, 0), res;
        for (auto &e : edges) {
            adj[e[0]].push_back(e[1]);
            in[e[1]]++;
        }
        queue<int> q;
        for (int i = 0; i < V; i++)
            if (!in[i])
                q.push(i);
        while (!q.empty()) {
            int u = q.front();
            q.pop();
            res.push_back(u);
            for (int v : adj[u])
                if (--in[v] == 0)
                    q.push(v);
        }
        return res;
    }
};Code (Java)
class Solution {
    public static ArrayList<Integer> topoSort(int V, int[][] edges) {
        ArrayList<ArrayList<Integer>> g = new ArrayList<>();
        int[] in = new int[V];
        ArrayList<Integer> res = new ArrayList<>();
        for (int i = 0; i < V; i++) g.add(new ArrayList<>());
        for (int[] e : edges) {
            g.get(e[0]).add(e[1]);
            in[e[1]]++;
        }
        Queue<Integer> q = new LinkedList<>();
        for (int i = 0; i < V; i++) if (in[i] == 0) q.add(i);
        while (!q.isEmpty()) {
            int u = q.poll();
            res.add(u);
            for (int v : g.get(u)) if (--in[v] == 0) q.add(v);
        }
        return res;
    }
}Code (Python)
from collections import deque
class Solution:
    def topoSort(self, V, edges):
        g = [[] for _ in range(V)]
        in_deg = [0] * V
        res = []
        for u, v in edges:
            g[u].append(v)
            in_deg[v] += 1
        q = deque(i for i in range(V) if in_deg[i] == 0)
        while q:
            u = q.popleft()
            res.append(u)
            for v in g[u]:
                in_deg[v] -= 1
                if in_deg[v] == 0:
                    q.append(v)
        return resContribution and Support:
For discussions, questions, or doubts related to this solution, feel free to connect on LinkedIn: Any Questions. Let’s make this learning journey more collaborative!
⭐ If you find this helpful, please give this repository a star! ⭐
📍Visitor Count
Last updated