Skip to content

Latest commit

 

History

History
35 lines (21 loc) · 1.42 KB

README.md

File metadata and controls

35 lines (21 loc) · 1.42 KB

Topological Sort

Topological sorting for Directed Acyclic Graph (DAG) is a linear ordering of vertices such that for every directed edge uv, vertex u comes before v in the ordering. Topological Sorting for a graph is not possible if the graph is not a DAG.

Algorithm

  1. Find any vertex v with in-degree zero
  2. Add v in sorted array
  3. Remove vertex v and all edges emanating from it from the directed graph
  4. Repeat from Step 1, until all vertices have been added to sorted array

Example:

Topological Sort Topological Sort Topological Sort Topological Sort Topological Sort

Courtesy: HackerEarth

Time Complexity

Total Time = O(|V|^2 + |E|) Here, O(|V|^2) is the time complexity for finding a vertex with in-degree zero, and O(|E|) is the time complexity for reducing in-degree of all the adjacent vertices by one on deletion of the vertex.

See also