Simplify Your Workflow: Search MiniWebtool.
Add Extension
Home Page > Math > Advanced Math Operations > Topological Sort Calculator

Topological Sort Calculator

Compute a topological ordering of a directed acyclic graph (DAG) using Kahn's algorithm or DFS. Detects cycles, reports the cycle path, builds a parallel-execution layer view, supports lexicographically smallest ordering, and animates each step on an interactive graph.

Topological Sort Calculator
Edge format: A -> B (also accepts , =>, :). Max 80 vertices / 800 edges.
Kahn's algorithm (lexicographic) gives a unique, reproducible order. DFS post-order is the classic depth-first method.

Embed Topological Sort Calculator Widget

About Topological Sort Calculator

The Topological Sort Calculator computes a linear ordering of the vertices of a directed acyclic graph (DAG) such that every directed edge from u to v places u before v. Enter your graph as an edge list or adjacency list and the tool returns the topological order using Kahn's algorithm or DFS post-order, detects cycles (with the exact cycle path), groups tasks into parallel-execution layers, counts the number of valid orderings, and animates each step on an interactive graph.

What is a topological sort?

Given a directed graph G = (V, E), a topological sort (or topological ordering) is a linear arrangement v₁, v₂, …, vₙ of its vertices such that for every directed edge (u → v), u appears before v in the arrangement. A topological ordering exists if and only if the graph has no directed cycles — that is, the graph is a DAG. The ordering is rarely unique: a graph can have many valid topological sorts when several vertices have in-degree zero at the same time.

Topological order definition
A permutation (v₁, v₂, …, vn) of V is topological iff
for every edge (u → v) in E: position(u) < position(v)

Algorithms used by this calculator

Kahn's algorithm (BFS-based, 1962)

Kahn's algorithm is the most intuitive topological sort. At every step it picks a vertex with in-degree zero (no incoming edges), appends it to the output, and "removes" it from the graph by decrementing the in-degree of each of its successors. When several vertices have in-degree zero, tie-breaking can use a min-heap (giving the lexicographically smallest ordering) or a FIFO queue (giving the insertion order). Kahn's algorithm runs in O(|V| + |E|) time and doubles as a cycle detector: if any vertex still has in-degree > 0 after the queue empties, the graph has a cycle.

Kahn's algorithm (pseudocode)
Kahn(G):
  Q ← { v ∈ V : indeg(v) = 0 }
  L ← [ ]
  while Q not empty:
    u ← Q.pop()
    L.append(u)
    for each edge u → v:
      indeg(v) -= 1
      if indeg(v) = 0: Q.push(v)
  if |L| < |V|: report cycle
  else: return L

DFS post-order (Tarjan, 1976)

The DFS algorithm runs depth-first search, and whenever a vertex finishes (i.e. all its successors have been fully explored) it is pushed onto a stack. Reversing the stack at the end yields a valid topological order. Cycle detection is natural: encountering a vertex that is still in progress (marked GRAY) means a back edge has been found, so the graph is not a DAG. DFS post-order also runs in O(|V| + |E|) time.

DFS post-order (pseudocode)
DFS-Topo(G):
  for each vertex u in V: color[u] ← WHITE
  L ← empty stack
  for each vertex u in V:
    if color[u] = WHITE: visit(u)
  return reverse(L)

visit(u):
  color[u] ← GRAY
  for each edge u → v:
    if color[v] = GRAY: report cycle
    if color[v] = WHITE: visit(v)
  color[u] ← BLACK; L.push(u)

Parallel-execution layers

A layered view of a DAG partitions its vertices into levels such that every edge goes from a lower-numbered level to a higher one. Vertices in the same layer are independent of each other, so they can be executed in parallel. The number of layers equals the length of the longest path plus one — this is the critical path of the DAG, the minimum number of sequential rounds needed to finish all tasks even with unlimited parallelism. This calculator produces the layer view automatically whenever the input is a DAG.

Cycle detection

If the graph contains a directed cycle, no topological sort is possible. Our calculator reports the exact cycle path (e.g. A → B → C → A) and highlights the cycle edges in red on the visualization. Removing any single edge on the cycle is sufficient to restore acyclicity.

Input formats

Edge list

Write each directed edge as source -> target, separated by commas or newlines. Accepted arrow variants: ->, , =>, -->, :. You can also chain edges: A -> B -> C is shorthand for A->B and B->C. Vertex labels can be letters, digits, underscores, dashes, and dots.

A -> B, B -> C, A -> C
C -> D
Shirt -> Tie -> Jacket

Adjacency list

Write each vertex, a colon, and its direct successors (vertices it points to). A vertex with no successors still needs its line, such as D:.

A: B, C
B: D
C: D
D:

How to use this calculator

  1. Pick a format: Toggle between edge list and adjacency list with the radio buttons.
  2. Enter the graph: Paste your data or click one of the quick examples (dressing order, course prerequisites, build targets, a graph with a cycle, and more).
  3. Choose an algorithm: Kahn's lexicographic for a unique, reproducible order; insertion order to preserve input ordering; DFS post-order for the classic depth-first method; or Show all to see every ordering side-by-side.
  4. Click "Sort Topologically": The ordering, cycle detection, layer view, critical path length, total number of valid orderings, and an interactive graph appear below.
  5. Explore: Press Play to watch each vertex get emitted one step at a time. The in-degree badges update live. Drag any node to rearrange the layout.

Real-world applications

Build systems and compilers

Tools like make, Bazel, Gradle, and npm topologically sort their build targets so each target is compiled only after all its dependencies. A cycle in the dependency graph is usually reported as a fatal error — the build system cannot decide where to start.

Task scheduling

Project managers use DAGs to capture task dependencies. The topological sort gives a valid execution order, and the layer view gives the minimum number of rounds under unlimited parallelism. The longest chain is the critical path that determines project duration.

Course prerequisite planning

A university course catalog is a DAG: edges are prerequisite relationships. A topological order is a valid study plan, and the layers tell students which sets of courses they can take in parallel during each semester.

Spreadsheet recalculation

When a cell changes, a spreadsheet must recompute every downstream cell in dependency order — a topological sort of the cell-dependency DAG. Circular references (cycles) are rejected by the application.

Package managers and plugin loaders

Apt, pip, Homebrew, Maven and countless plugin frameworks resolve install or load order by topologically sorting their dependency DAGs.

Symbol resolution and instruction scheduling

Compilers use topological sort to order declarations, and CPUs use data-dependency DAGs to schedule instructions in the reorder buffer without violating data hazards.

Counting topological orderings

For a DAG with n vertices, the number of distinct valid topological orderings can range from 1 (for a totally ordered chain) to n! (for the edgeless graph). Computing the exact count is #P-complete in general, but for graphs up to 16 vertices this calculator enumerates them using a bitmask dynamic-programming formulation: f(S) = Σ f(S ∪ {v}) over all v ∉ S whose predecessors are all in S.

Complexity and performance

Frequently asked questions

What is a topological sort?

A topological sort of a directed acyclic graph is a linear ordering of its vertices such that every directed edge from u to v places u before v. It represents a valid order in which to process tasks that respect their dependencies.

Which algorithm does this calculator use?

The calculator runs both Kahn's algorithm and DFS post-order. Kahn's algorithm repeatedly removes a vertex with in-degree zero and decrements in-degrees of its successors. DFS post-order runs depth-first search and reverses the finish order. Both run in O(|V| + |E|) time.

What if my graph has a cycle?

A graph with a directed cycle has no topological sort. The calculator detects the cycle, highlights it in red on the visualization, and reports the exact cycle path so you can see which edges to remove to make the graph a DAG.

What is the lexicographically smallest topological order?

When many topological orderings are valid, the lexicographically smallest one is obtained by always picking the alphabetically smallest vertex whose in-degree is zero at each step. The default Kahn's mode of this calculator returns this unique ordering, which is stable and easy to reproduce.

What is the layer or level view?

The layer view groups vertices by the longest path length from any source. Vertices in the same layer have no dependency between them, so they can run in parallel. The number of layers equals the longest dependency chain plus one and gives the minimum number of parallel rounds needed to finish all tasks.

Can a graph have many valid topological orderings?

Yes. If at any step Kahn's algorithm has multiple vertices with in-degree zero, any of them can be picked next. This calculator counts the exact number of distinct topological orderings for graphs up to 16 vertices.

What is the difference between Kahn's algorithm and DFS post-order?

Kahn's works top-down: it repeatedly picks sources (in-degree 0) and emits them first. DFS post-order works bottom-up: it finishes sinks first and prepends them to the order. Both are O(|V| + |E|) and produce valid topological orderings, but typically different ones. Kahn's is easier to parallelize and to adapt for lexicographic ordering; DFS is easier to combine with other DFS-based analyses such as strongly connected components.

What is the maximum graph size this tool supports?

The calculator supports up to 80 vertices and 800 edges. Counting the total number of valid topological orderings is capped at 16 vertices because the problem is #P-complete and the state space grows as 2ⁿ. The interactive visualization and algorithm animation scale smoothly up to the full size.

Further Reading

Reference this content, page, or tool as:

"Topological Sort Calculator" at https://MiniWebtool.com/topological-sort-calculator/ from MiniWebtool, https://MiniWebtool.com/

by miniwebtool team. Updated: Apr 20, 2026

You can also try our AI Math Solver GPT to solve your math problems through natural language question and answer.

Related MiniWebtools:

Advanced Math Operations:

Top & Updated:

Random Name PickerRandom PickerInstagram User ID LookupFPS ConverterLine CounterSort NumbersRelative Standard Deviation CalculatorImage ResizerMAC Address GeneratorBatting Average CalculatorRemove SpacesFacebook User ID LookupRandom Truth or Dare GeneratorERA CalculatorFeet and Inches to Cm ConverterWord to Phone Number ConverterMAC Address LookupSun, Moon & Rising Sign Calculator 🌞🌙✨Slope and Grade CalculatorPercent Off CalculatorMP3 LooperSum Calculator📷 OCR / Image to TextBitwise CalculatorRandom IMEI GeneratorAudio SplitterInvisible Text GeneratorRoman Numerals ConverterRandom Superpower GeneratorAI Text HumanizerWord Ladder GeneratorRandom Credit Card GeneratorVertical Jump CalculatorSHA256 Hash GeneratorNumber of Digits CalculatorRandom Quote GeneratorHalfway Date CalculatorLog Base 10 CalculatorMerge VideosWAR CalculatorRandom Birthday Generator⬛ Aspect Ratio CalculatorSalary Conversion CalculatorCm to Feet and Inches ConverterMaster Number CalculatorRandom Fake Address GeneratorSaturn Return CalculatorPhone Number ExtractorRandom Activity GeneratorRandom Meal GeneratorOPS CalculatorFile Size ConverterOn Base Percentage CalculatorNumber to Word ConverterIP Subnet CalculatorRandom Writing Prompt GeneratorText FormatterSquare Root (√) CalculatorRandom Poker Hand GeneratorCompound Growth CalculatorSlugging Percentage CalculatorYouTube Channel StatisticsCaffeine Overdose CalculatorBinary to Gray Code ConverterLove Compatibility CalculatorDecimal to BCD ConverterRandom Loadout GeneratorRandom Movie PickerVideo to Image ExtractorBCD to Decimal ConverterOctal CalculatorBattery Life CalculatorMercury Retrograde CalendarLeap Years List🖱️ Click CounterCompare Two StringsStair Calculator📅 Date CalculatorFirst n Digits of PiConnect the Dots GeneratorCM to Inches ConverterRemove Accent🎰 Gacha Pity CalculatorSHA512 Hash GeneratorAdd Text to ImagePercent Growth Rate CalculatorWeight Loss CalculatorPER CalculatorGray Code to Binary ConverterRandom Object GeneratorLottery Number GeneratorBingo Card GeneratorAdd Prefix and Suffix to TextImage CompressorImage SplitterOutlier CalculatorCoin FlipperAstrological Element Balance CalculatorSmall Text Generator ⁽ᶜᵒᵖʸ ⁿ ᵖᵃˢᵗᵉ⁾Arc Length CalculatorVideo CompressorNumber ExtractorTime Duration CalculatorDay of the Year Calculator - What Day of the Year Is It Today?Quotient and Remainder CalculatorWhat is my Lucky Number?Diff CheckerMultiple Fraction CalculatorFlip VideoList of Prime NumbersProportion CalculatorRandom Emoji GeneratorWhat is my Zodiac Sign?Acreage CalculatorWord Scramble GeneratorIP Address to Hex ConverterBcrypt Hash Generator / CheckerMandelbrot Set ExplorerAngel Number CalculatorBreak Line by CharactersLongest Day of the YearURL ExtractorRandom Line PickerRandom Time GeneratorCone Flat Pattern (Template) GeneratorModulo CalculatorTessellation GeneratorName Number CalculatorBinary to BCD ConverterDay of Year CalendarAI Language DetectorEmail ExtractorDNS LookupRandom Chess Opening Generator🔍 Plagiarism CheckerVideo SplitterMiter Angle CalculatorWHIP CalculatorAntilog CalculatorMD5 Hash GeneratorLunar Calendar ConverterYouTube Tag ExtractorCrossword Puzzle MakerRandomize NumbersRemove Leading Trailing SpacesMartingale Strategy CalculatorRandom Chord GeneratorDMS to Decimal Degrees ConverterIs it a Prime Number?Steel Weight CalculatorAdjust Video SpeedAI Punctuation AdderLong Division CalculatorRandom Number PickerMolarity CalculatorFirst n Digits of eCollage MakerPercentile CalculatorShort Selling Profit CalculatorArctan2 CalculatorJulia Set GeneratorRandom User-Agent GeneratorHeight Percentile CalculatorBolt Torque CalculatorHypotenuse CalculatorMorse Code GeneratorBroken Link CheckerRandom Tournament Bracket GeneratorColor InverterRandom Group GeneratorBonus CalculatorFraction CalculatorHTML CompressorMultiplication CalculatorRounding CalculatorAI ParaphraserPregnancy CalendarYouTube Earnings EstimatorName RandomizerRandom Name GeneratorRatio to Percentage CalculatorBirth Day of the Week CalculatorBoiling Point CalculatorMAC Address AnalyzerPizza Value CalculatorDestiny Number CalculatorSocial Media Username CheckerPVIF CalculatorPVIFA CalculatorGrade CalculatorField Goal Percentage CalculatorSquare Numbers ListHebrew Calendar ConverterLife Path Number CalculatorDue Date CalculatorBoxing Punch Power CalculatorTaco Bar Calculator🎲 Loot Drop Probability CalculatorSort Lines AlphabeticallyHex to BCD ConverterBCD to Binary ConverterBCD to Hex ConverterMedian CalculatorStandard Error CalculatorList RandomizerAverage CalculatorReverse VideoRemove Audio from VideoActual Cash Value CalculatorScientific Notation to Decimal ConverterLog Base 2 CalculatorRoot Mean Square CalculatorSum of Positive Integers CalculatorSHA3-256 Hash GeneratorAI Sentence ExpanderLbs to Kg ConverterHex to Decimal ConverterConvolution CalculatorRandom String GeneratorAmortization CalculatorMarkup CalculatorDecimal to Hex ConverterInstagram Font GeneratorSocial Media Image Size GuideTikTok Money CalculatorTwitter/X Character CounterTwitter/X Timestamp ConverterYouTube Watch Time CalculatorTwitch Earnings CalculatorYouTube Shorts Monetization CalculatorFacebook Ad Cost CalculatorSocial Media ROI CalculatorSocial Media Post Time OptimizerCTR CalculatorROAS CalculatorInfluencer ROI CalculatorForce CalculatorAcceleration CalculatorVelocity CalculatorMomentum CalculatorProjectile Motion CalculatorKinetic Energy CalculatorPotential Energy CalculatorWork and Power CalculatorDensity CalculatorPressure CalculatorIdeal Gas Law CalculatorFree Fall CalculatorTorque CalculatorHorsepower CalculatorDilution CalculatorChemical Equation BalancerStoichiometry CalculatorPercent Yield CalculatorEmpirical Formula CalculatorTitration CalculatorMole/Gram/Particle ConverterIrregular Polygon Area CalculatorFrustum CalculatorTorus Calculator3D Distance CalculatorGreat Circle Distance CalculatorCircumscribed Circle (Circumcircle) CalculatorInscribed Circle (Incircle) CalculatorAngle Bisector CalculatorTangent Line to Circle CalculatorHeron's Formula CalculatorCoordinate Geometry Distance CalculatorVolume of Revolution CalculatorSurface of Revolution CalculatorParametric Curve GrapherRiemann Sum CalculatorTrapezoidal Rule CalculatorSimpson's Rule CalculatorImproper Integral CalculatorL'Hôpital's Rule CalculatorMaclaurin Series CalculatorPower Series CalculatorSeries Convergence Test CalculatorInfinite Series Sum CalculatorAverage Rate of Change CalculatorInstantaneous Rate of Change CalculatorRelated Rates SolverOptimization Calculator (Calculus)Gradient Calculator (Multivariable)Divergence CalculatorCurl CalculatorLine Integral CalculatorSurface Integral CalculatorJacobian Matrix CalculatorNewton's Method CalculatorRREF Calculator (Row Echelon Form)Matrix Inverse CalculatorMatrix Multiplication CalculatorDot Product CalculatorCross Product CalculatorVector Magnitude CalculatorUnit Vector CalculatorAngle Between Vectors CalculatorNull Space CalculatorColumn Space CalculatorCramer's Rule CalculatorMatrix Diagonalization CalculatorQR Decomposition CalculatorCholesky Decomposition CalculatorMatrix Power CalculatorCharacteristic Polynomial CalculatorBayes' Theorem CalculatorF-Test / F-Distribution CalculatorHypergeometric Distribution CalculatorNegative Binomial Distribution CalculatorGeometric Distribution CalculatorExponential Distribution CalculatorWeibull Distribution CalculatorBeta Distribution CalculatorSpearman Rank Correlation CalculatorFisher's Exact Test CalculatorContingency Table CalculatorOdds Ratio CalculatorROT13 Encoder/DecoderAtbash Cipher ToolVigenère Cipher ToolPronunciation IPA ConverterHemingway-Style Readability EditorSentence Length Variance AnalyzerWord Frequency AnalyzerBusiness Days CalculatorAdd Business Days to DateDate Pattern GeneratorHow Long Until CalculatorHow Long Ago CalculatorBirthday Across Cultures CalculatorHijri Calendar ConverterInsulin Sensitivity Factor CalculatorCarb-to-Insulin Ratio CalculatorLean Body Mass to Strength CalculatorOne-Mile Walk Test (Rockport) CalculatorCooper 12-Minute Run CalculatorFFMI CalculatorAPGAR Score CalculatorGlasgow Coma Scale CalculatorWells Score Calculator (DVT/PE)Tennis Score TrackerSoccer xG (Expected Goals) CalculatorCricket Run Rate CalculatorRugby Points CalculatorRace Time PredictorSwimming SWOLF CalculatorYoga Pose Hold TimerFishing Knot Strength CalculatorBike Gear Ratio CalculatorClimbing Grade ConverterWine Pairing SuggesterStandard Drink CalculatorCaffeine Half-Life TrackerSpice Substitution FinderDietary Restriction Recipe FilterMarinade Time CalculatorFermentation Time CalculatorSmoking Wood Pairing GuideFreelance Project Pricing CalculatorSaaS Pricing CalculatorSubscription Cost TrackerSide Hustle ROI CalculatorRemote Work Savings CalculatorCoffee Habit Cost CalculatorGym vs Home Workout Cost CalculatorLunch Cost CalculatorWealth Growth Visualizer1031 Exchange CalculatorRental Yield CalculatorCash-on-Cash Return CalculatorBRRRR Method CalculatorSection 8 Rent CalculatorRoommate Rent SplitterAirbnb Pricing OptimizerStatute of Limitations CalculatorSentence Reduction CalculatorSales Tax Nexus CheckerPatent Filing Fee CalculatorTrademark Class FinderWill Asset Distribution CalculatorWorkers' Compensation CalculatorStopping Distance CalculatorTrip Cost SplitterVehicle Weight Distribution CalculatorTrailer Tongue Weight CalculatorTire Tread Wear CalculatorEngine Compression Ratio CalculatorHeadlight Beam Distance CalculatorCat Litter Box CalculatorAquarium Heater Wattage CalculatorBird Cage Size CalculatorReptile Habitat UVB CalculatorPet Travel Crate Size FinderHorse Hay CalculatorCrochet Hook Size ConverterKnitting Needle Size ConverterKnitting Pattern CalculatorCross-Stitch Floss CalculatorQuilt Binding CalculatorOrigami Paper Size CalculatorPottery Clay Shrinkage CalculatorBeading Pattern CalculatorResin Casting Volume CalculatorEmbroidery Thread Length CalculatorHiking Pace Calculator (Naismith's Rule)Backpacking Food Weight CalculatorTent Footprint Size CalculatorSleeping Bag Temperature Rating GuideKnot Tying Reference ToolStar Visibility CalculatorTide Time CalculatorSun Position CalculatorReynolds Number CalculatorBernoulli Equation CalculatorHeat Transfer CalculatorThermal Expansion CalculatorSpecific Heat Capacity CalculatorGear Ratio Calculator (Mechanical)Pulley System CalculatorHydraulic Cylinder Force CalculatorBelt Length CalculatorCloset Capsule CalculatorStorage Unit Size CalculatorMoving Box Quantity CalculatorGift Card Tip CalculatorGas vs Electric Cost ComparisonPrint Cost CalculatorHair Dye Mixing CalculatorLaundry Detergent Dosage CalculatorDishwasher Load OptimizerTile Grout CalculatorPaint Color Mixing CalculatorFlashcard Spaced Repetition SchedulerLearning Curve CalculatorCornell Notes GeneratorVocabulary Quiz GeneratorLanguage Learning Hours to Fluency CalculatorCollege Cost CalculatorScholarship ROI Calculator