
Topological Sort in Data Structures
Learn about topological sorting in data structures and algorithms, including its significance, examples, terminology, and applications. Understand the process through a first algorithm to perform topological sort efficiently.
Download Presentation

Please find below an Image/Link to download the presentation.
The content on the website is provided AS IS for your information and personal use only. It may not be sold, licensed, or shared on other websites without obtaining consent from the author. If you encounter any issues during the download, it is possible that the publisher has removed the file from their server.
You are allowed to download the files provided on this website for personal or commercial use, subject to the condition that they are used lawfully. All files are the property of their respective owners.
The content on the website is provided AS IS for your information and personal use only. It may not be sold, licensed, or shared on other websites without obtaining consent from the author.
E N D
Presentation Transcript
Announcements Revised office hours for Dan this week See email Review session tomorrow, 2-3pm Final review session poll out Today s lecture: Lots of material Important to review on your own very mechanical. Summer 2016 CSE373: Data Structures & Algorithms 1
CSE373: Data Structures & Algorithms Topological Sort / Graph Traversals / Dijkstra s Hunter Zahn Summer 2016 Summer 2016 CSE373: Data Structures & Algorithms 2
Disclaimer: This may be wrong. Dont base your course schedules on this Material. Please Topological Sort Problem: Given a DAG G=(V,E), output all vertices in an order such that no vertex appears before another vertex that has an edge to it XYZ CSE 374 Example input: CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 One example output: 126, 142, 143, 374, 373, 417, 410, 413, XYZ, 415 CSE373: Data Structures & Summer 2016 3 Algorithms
Questions and comments Why do we perform topological sorts only on DAGs? Because a cycle means there is no correct answer Is there always a unique answer? No, there can be 1 or more answers; depends on the graph Graph with 5 topological orders: 2 Do some DAGs have exactly 1 answer? Yes, including all lists 0 4 3 1 Terminology: A DAG represents a partial order and a topological sort produces a total order that is consistent with it CSE373: Data Structures & Summer 2016 4 Algorithms
Uses Figuring out how to graduate Computing an order in which to recompute cells in a spreadsheet Determining an order to compile files using a Makefile In general, taking a dependency graph and finding an order of execution CSE373: Data Structures & Summer 2016 5 Algorithms
A First Algorithm for Topological Sort 1. Label ( mark ) each vertex with its in-degree Think write in a field in the vertex Could also do this via a data structure (e.g., array) on the side 2. While there are vertices not yet output: a) Choose a vertex v with labeled with in-degree of 0 b) Output v and conceptually remove it from the graph c) For each vertex u adjacent to v (i.e. u such that (v,u) in E), decrement the in-degree of u CSE373: Data Structures & Summer 2016 6 Algorithms
Example Output : XYZ CSE 374 CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 Node: 126 142 143 374 373 410 413 415 417 XYZ Removed? In-degree: 0 0 2 1 1 1 1 1 1 3 CSE373: Data Structures & Summer 2016 7 Algorithms
Example Output : 126 XYZ CSE 374 CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 Node: 126 142 143 374 373 410 413 415 417 XYZ Removed? x In-degree: 0 0 2 1 1 1 1 1 1 3 1 CSE373: Data Structures & Summer 2016 8 Algorithms
Example Output : 126 142 XYZ CSE 374 CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 Node: 126 142 143 374 373 410 413 415 417 XYZ Removed? x x In-degree: 0 0 2 1 1 1 1 1 1 3 1 0 CSE373: Data Structures & Summer 2016 9 Algorithms
Example Output : 126 142 143 XYZ CSE 374 CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 Node: 126 142 143 374 373 410 413 415 417 XYZ Removed? x x x In-degree: 0 0 2 1 1 1 1 1 1 3 1 0 0 0 CSE373: Data Structures & Summer 2016 10 Algorithms
Example Output : 126 142 143 374 XYZ CSE 374 CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 Node: 126 142 143 374 373 410 413 415 417 XYZ Removed? x x x x In-degree: 0 0 2 1 1 1 1 1 1 3 1 0 0 2 0 CSE373: Data Structures & Summer 2016 11 Algorithms
Example Output : 126 142 143 374 373 XYZ CSE 374 CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 Node: 126 142 143 374 373 410 413 415 417 XYZ Removed? x x x x x In-degree: 0 0 2 1 1 1 1 1 1 3 1 0 0 0 0 0 0 2 0 CSE373: Data Structures & Summer 2016 12 Algorithms
Example Output : 126 142 143 374 373 417 XYZ CSE 374 CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 Node: 126 142 143 374 373 410 413 415 417 XYZ Removed? x x x x x x In-degree: 0 0 2 1 1 1 1 1 1 3 1 0 0 0 0 0 0 2 0 CSE373: Data Structures & Summer 2016 13 Algorithms
Example Output: 126 142 143 374 373 417 410 XYZ CSE 374 CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 Node: 126 142 143 374 373 410 413 415 417 XYZ Removed? x x x x x x x In-degree: 0 0 2 1 1 1 1 1 1 3 1 0 0 0 0 0 0 2 0 1 CSE373: Data Structures & Summer 2016 14 Algorithms
Example Output: 126 142 143 374 373 417 410 413 XYZ CSE 374 CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 Node: 126 142 143 374 373 410 413 415 417 XYZ Removed? x x x x x x x x In-degree: 0 0 2 1 1 1 1 1 1 3 1 0 0 0 0 0 0 2 0 1 CSE373: Data Structures & Summer 2016 15 Algorithms 0
Example Output: 126 142 143 374 373 417 410 413 XYZ XYZ CSE 374 CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 Node: 126 142 143 374 373 410 413 415 417 XYZ Removed? x x x x x x x x x In-degree: 0 0 2 1 1 1 1 1 1 3 1 0 0 0 0 0 0 2 0 1 CSE373: Data Structures & Summer 2016 16 Algorithms 0
Example Output: 126 142 143 374 373 417 410 413 XYZ 415 XYZ CSE 374 CSE 410 CSE 142 CSE 143 CSE 373 CSE 413 CSE 415 MATH 126 CSE 417 Node: 126 142 143 374 373 410 413 415 417 XYZ Removed? x x x x x x x x x x In-degree: 0 0 2 1 1 1 1 1 1 3 1 0 0 0 0 0 0 2 0 1 CSE373: Data Structures & Summer 2016 17 Algorithms 0
Notice Needed a vertex with in-degree 0 to start Will always have at least 1 because no cycles Ties among vertices with in-degrees of 0 can be broken arbitrarily Can be more than one correct answer, by definition, depending on the graph CSE373: Data Structures & Summer 2016 18 Algorithms
Running time? labelEachVertexWithItsInDegree(); for(ctr=0; ctr < numVertices; ctr++){ v = findNewVertexOfDegreeZero(); put v next in output for each w adjacent to v w.indegree--; } CSE373: Data Structures & Summer 2016 19 Algorithms
Running time? labelEachVertexWithItsInDegree(); for(ctr=0; ctr < numVertices; ctr++){ v = findNewVertexOfDegreeZero(); put v next in output for each w adjacent to v w.indegree--; } What is the worst-case running time? Initialization O(|V|+|E|) (assuming adjacency list) Outer loop: runs |V| times findNewVertex: O(|V|) Sum of all decrements O(|E|) (assuming adjacency list) (each edge is removed once) So total is O(|V|2) not good for a sparse graph! CSE373: Data Structures & Summer 2016 20 Algorithms
Doing better The trick is to avoid searching for a zero-degree node every time! Keep the pending zero-degree nodes in a list, stack, queue, bag, table, or something Order we process them affects output but not correctness or efficiency provided add/remove are both O(1) Using a queue: 1. Label each vertex with its in-degree, enqueue 0-degree nodes 2. While queue is not empty a) v = dequeue() b) Output v and remove it from the graph c) For each vertex u adjacent to v (i.e. u such that (v,u) in E), decrement the in-degree of u, if new degree is 0, enqueue it CSE373: Data Structures & Summer 2016 21 Algorithms
Running time? labelAllAndEnqueueZeros(); while queue not empty { v = dequeue(); put v next in output for each w adjacent to v { w.indegree--; if (w.indegree==0) enqueue(v); } } CSE373: Data Structures & Summer 2016 22 Algorithms
Running time? labelAllAndEnqueueZeros(); while queue not empty { v = dequeue(); put v next in output for each w adjacent to v { w.indegree--; if (w.indegree==0) enqueue(v); } } What is the worst-case running time? Initialization: O(|V|+|E|) (assuming adjacenty list) Sum of all enqueues and dequeues: O(|V|) Sum of all decrements: O(|E|) (assuming adjacency list) So total is O(|E| + |V|) much better for sparse graph! CSE373: Data Structures & Summer 2016 23 Algorithms
Graph Traversals Next problem: For an arbitrary graph and a starting node v, find all nodes reachable from v (i.e., there exists a path from v) Possibly do something for each node Examples: print to output, set a field, etc. Subsumed problem: Is an undirected graph connected? Related but different problem: Is a directed graph strongly connected? Need cycles back to starting node Basic idea: Keep following nodes But mark nodes after visiting them, so the traversal terminates and processes each reachable node exactly once CSE373: Data Structures & Summer 2016 24 Algorithms
Abstract Idea void traverseGraph(Node start) { Set pending = emptySet() pending.add(start) mark start as visited while(pending is not empty) { next = pending.remove() for each node u adjacent to next if (u is not marked) { mark u pending.add(u) } } } CSE373: Data Structures & Summer 2016 25 Algorithms
Running Time and Options Assuming add and remove are O(1), entire traversal is O(|E|) Use an adjacency list representation The order we traverse depends entirely on add and remove Popular choice: a stack depth-first graph search DFS Popular choice: a queue breadth-first graph search BFS DFS and BFS are big ideas in computer science Depth: recursively explore one part before going back to the other parts not yet explored Breadth: explore areas closer to the start node first Cool visualization: http://visualgo.net/dfsbfs.html Summer 2016 CSE373: Data Structures & Algorithms 26
Example: trees A tree is a graph and DFS and BFS are particularly easy to see DFS(Node start) { mark and process start for each node u adjacent to start if u is not marked DFS(u) } A B C D E F G H A, B, D, E, C, F, G, H Exactly what we called a pre-order traversal for trees The marking is because we support arbitrary graphs and we want to process each node exactly once CSE373: Data Structures & Summer 2016 27 Algorithms
Example: trees A tree is a graph and DFS and BFS are particularly easy to see DFS2(Node start) { initialize stack s to hold start mark start as visited while(s is not empty) { next = s.pop() // and process for each node u adjacent to next if(u is not marked) mark u and push onto s } } A B C D E F G H A, C, F, H, G, B, E, D A different but perfectly fine traversal CSE373: Data Structures & Summer 2016 28 Algorithms
Example: trees A tree is a graph and DFS and BFS are particularly easy to see BFS(Node start) { initialize queue q to hold start mark start as visited while(q is not empty) { next = q.dequeue() // and process for each node u adjacent to next if(u is not marked) mark u and enqueue onto q } } A B C D E F G H A, B, C, D, E, F, G, H A level-order traversal CSE373: Data Structures & Summer 2016 29 Algorithms
Comparison Breadth-first always finds shortest paths, i.e., optimal solutions Better for what is the shortest path from x to y But depth-first can use less space in finding a path If longest path in the graph is p and highest out-degree is d then DFS stack never has more than d*p elements But a queue for BFS may hold O(|V|) nodes A third approach: Iterative deepening (IDFS): Try DFS but disallow recursion more than K levels deep If that fails, increment K and start the entire search over Like BFS, finds shortest paths. Like DFS, less space. CSE373: Data Structures & Summer 2016 30 Algorithms
Saving the Path Our graph traversals can answer the reachability question: Is there a path from node x to node y? But what if we want to actually output the path? Like getting driving directions rather than just knowing it s possible to get there! How to do it: Instead of just marking a node, store the previous node along the path (when processing u causes us to add v to the search, set v.path field to be u) When you reach the goal, follow path fields back to where you started (and then reverse the answer) If just wanted path length, could put the integer distance at each node instead CSE373: Data Structures & Summer 2016 31 Algorithms
Example using BFS What is a path from Seattle to Tyler Remember marked nodes are not re-enqueued Note shortest paths may not be unique 0 1 Chicago Seattle Salt Lake City 1 Tyler 1 3 San Francisco 2 Dallas CSE373: Data Structures & Summer 2016 32 Algorithms
Shortest Paths Hunter Zahn Summer 2016 Summer 2016 CSE373: Data Structures & Algorithms 33
Single source shortest paths Done: BFS to find the minimum path length from v to u in O(|E|+|V|) Actually, can find the minimum path length from v to every node Still O(|E|+|V|) No faster way for a distinguished destination in the worst-case Now: Weighted graphs Given a weighted graph and node v, find the minimum-cost path from v to every node As before, asymptotically no harder than for one destination Unlike before, BFS will not work CSE373: Data Structures & Summer 2016 34 Algorithms
Applications Driving directions Cheap flight itineraries Network routing Critical paths in project management CSE373: Data Structures & Summer 2016 35 Algorithms
Not as easy 10 5 100 100 100 A 100 B -11 7 500 Why BFS won t work: Shortest path may not have the fewest edges Annoying when this happens with costs of flights We will assume there are no negative weights Problem is ill-defined if there are negative-cost cycles Today s algorithm is wrong if edges can be negative There are other, slower (but not terrible) algorithms CSE373: Data Structures & Summer 2016 36 Algorithms
Dijkstra Algorithm named after its inventor Edsger Dijkstra (1930-2002) Truly one of the founders of computer science; this is just one of his many contributions My favorite Dijkstra quote: computer science is no more about computers than astronomy is about telescopes CSE373: Data Structures & Summer 2016 37 Algorithms
Dijkstras algorithm The idea: reminiscent of BFS, but adapted to handle weights Grow the set of nodes whose shortest distance has been computed Nodes not in the set will have a best distance so far A priority queue will turn out to be useful for efficiency CSE373: Data Structures & Summer 2016 38 Algorithms
Dijkstras Algorithm: Idea 0 2 2 4 2 3 B A F H 1 2 1 5 10 4 9 3 G 1 C 2 1 11 D 4 E 12 7 Initially, start node has cost 0 and all other nodes have cost At each step: Pick closest unknown vertex v Add it to the cloud of known vertices Update distances for nodes with edges from v That s it! (But we need to prove it produces correct answers) CSE373: Data Structures & Summer 2016 39 Algorithms
The Algorithm 1. For each node v, set v.cost = andv.known = false 2. Set source.cost = 0 3. While there are unknown nodes in the graph a) Select the unknown node v with lowest cost b) Mark v as known c) For each edge (v,u) with weight w, c1 = v.cost + w// cost of best path through v to u c2 = u.cost// cost of best path to u previously known if(c1 < c2){// if the path through v is better u.cost = c1 u.path = v// for computing actual paths } CSE373: Data Structures & Summer 2016 40 Algorithms
Important features When a vertex is marked known, the cost of the shortest path to that node is known The path is also known by following back-pointers While a vertex is still not known, another shorter path to it might still be found CSE373: Data Structures & Summer 2016 41 Algorithms
Example #1 0 2 2 3 B A F H 1 2 1 5 10 4 9 3 G C 2 1 11 D E 7 vertex A B C D E F G H known? cost 0 ?? ?? ?? ?? ?? ?? ?? path Order Added to Known Set: CSE373: Data Structures & Summer 2016 42 Algorithms
Example #1 2 0 2 2 3 B A F H 1 2 1 5 10 4 9 3 G 1 C 2 1 11 D 4 E 7 vertex A B C D E F G H known? Y cost 0 2 1 4 ?? ?? ?? ?? path A A A Order Added to Known Set: A CSE373: Data Structures & Summer 2016 43 Algorithms
Example #1 2 0 2 2 3 B A F H 1 2 1 5 10 4 9 3 G 1 C 2 1 11 D 4 E 12 7 vertex A B C D E F G H known? Y cost 0 2 1 4 12 ?? ?? ?? path A A A C Y Order Added to Known Set: A, C CSE373: Data Structures & Summer 2016 44 Algorithms
Example #1 4 3 2 0 2 2 B A F H 1 2 1 5 10 4 9 3 G 1 C 2 1 11 D 4 E 12 7 vertex A B C D E F G H known? Y Y Y cost 0 2 1 4 12 4 ?? ?? path A A A C B Order Added to Known Set: A, C, B CSE373: Data Structures & Summer 2016 45 Algorithms
Example #1 4 3 2 0 2 2 B A F H 1 2 1 5 10 4 9 3 G 1 C 2 1 11 D 4 E 12 7 vertex A B C D E F G H known? Y Y Y Y cost 0 2 1 4 12 4 ?? ?? path A A A C B Order Added to Known Set: A, C, B, D CSE373: Data Structures & Summer 2016 46 Algorithms
Example #1 4 3 2 7 0 2 2 B A F H 1 2 1 5 10 4 9 3 G 1 C 2 1 11 D 4 E 12 7 vertex A B C D E F G H known? Y Y Y Y cost 0 2 1 4 12 4 ?? 7 path A A A C B Order Added to Known Set: Y A, C, B, D, F F CSE373: Data Structures & Summer 2016 47 Algorithms
Example #1 4 3 2 7 0 2 2 B A F H 1 2 1 5 10 4 9 3 8 G 1 C 2 1 11 D 4 E 12 7 vertex A B C D E F G H known? Y Y Y Y cost 0 2 1 4 12 4 8 7 path A A A C B H F Order Added to Known Set: Y A, C, B, D, F, H Y CSE373: Data Structures & Summer 2016 48 Algorithms
Example #1 4 3 2 7 0 2 2 B A F H 1 2 1 5 10 4 9 3 8 G 1 C 2 1 11 D 4 E 11 7 vertex A B C D E F G H known? Y Y Y Y cost 0 2 1 4 11 4 8 7 path A A A G B H F Order Added to Known Set: Y Y Y A, C, B, D, F, H, G CSE373: Data Structures & Summer 2016 49 Algorithms
Example #1 4 3 2 7 0 2 2 B A F H 1 2 1 5 10 4 9 3 8 G 1 C 2 1 11 D 4 E 11 7 vertex A B C D E F G H known? Y Y Y Y Y Y Y Y cost 0 2 1 4 11 4 8 7 path A A A G B H F Order Added to Known Set: A, C, B, D, F, H, G, E CSE373: Data Structures & Summer 2016 50 Algorithms