MST Many of the slides are from Prof. Plaisted’s resources at University of North Carolina at Chapel Hill.

Slides:



Advertisements
Similar presentations
Comp 122, Spring 2004 Greedy Algorithms. greedy - 2 Lin / Devi Comp 122, Fall 2003 Overview  Like dynamic programming, used to solve optimization problems.
Advertisements

Greedy Algorithms Greed is good. (Some of the time)
Minimum Spanning Trees Definition Two properties of MST’s Prim and Kruskal’s Algorithm –Proofs of correctness Boruvka’s algorithm Verifying an MST Randomized.
Minimum Spanning Trees Definition of MST Generic MST algorithm Kruskal's algorithm Prim's algorithm.
Minimum Spanning Tree CSE 331 Section 2 James Daly.
Minimum Spanning Tree (MST) form a tree that connects all the vertices (spanning tree). minimize the total edge weight of the spanning tree. Problem Select.
UNC Chapel Hill Lin/Foskey/Manocha Minimum Spanning Trees Problem: Connect a set of nodes by a network of minimal total length Some applications: –Communication.
1 Greedy 2 Jose Rolim University of Geneva. Algorithmique Greedy 2Jose Rolim2 Examples Greedy  Minimum Spanning Trees  Shortest Paths Dijkstra.
Chapter 23 Minimum Spanning Trees
Data Structures, Spring 2004 © L. Joskowicz 1 Data Structures – LECTURE 13 Minumum spanning trees Motivation Properties of minimum spanning trees Kruskal’s.
Minimum Spanning Tree Algorithms
CSE 780 Algorithms Advanced Algorithms Minimum spanning tree Generic algorithm Kruskal’s algorithm Prim’s algorithm.
1 7-MST Minimal Spanning Trees Fonts: MTExtra:  (comment) Symbol:  Wingdings: Fonts: MTExtra:  (comment) Symbol:  Wingdings:
Lecture 18: Minimum Spanning Trees Shang-Hua Teng.
1 Minimum Spanning Trees Definition of MST Generic MST algorithm Kruskal's algorithm Prim's algorithm.
Greedy Algorithms Reading Material: Chapter 8 (Except Section 8.5)
Analysis of Algorithms CS 477/677
Lecture 12 Minimum Spanning Tree. Motivating Example: Point to Multipoint Communication Single source, Multiple Destinations Broadcast – All nodes in.
CSE Algorithms Minimum Spanning Trees Union-Find Algorithm
Greedy Algorithms Like dynamic programming algorithms, greedy algorithms are usually designed to solve optimization problems Unlike dynamic programming.
David Luebke 1 9/10/2015 CS 332: Algorithms Single-Source Shortest Path.
1.1 Data Structure and Algorithm Lecture 13 Minimum Spanning Trees Topics Reference: Introduction to Algorithm by Cormen Chapter 13: Minimum Spanning Trees.
Design and Analysis of Computer Algorithm September 10, Design and Analysis of Computer Algorithm Lecture 5-2 Pradondet Nilagupta Department of Computer.
Theory of Computing Lecture 10 MAS 714 Hartmut Klauck.
Definition: Given an undirected graph G = (V, E), a spanning tree of G is any subgraph of G that is a tree Minimum Spanning Trees (Ch. 23) abc d f e gh.
Algorithms: Design and Analysis Summer School 2013 at VIASM: Random Structures and Algorithms Lecture 3: Greedy algorithms Phan Th ị Hà D ươ ng 1.
2IL05 Data Structures Fall 2007 Lecture 13: Minimum Spanning Trees.
Spring 2015 Lecture 11: Minimum Spanning Trees
UNC Chapel Hill Lin/Foskey/Manocha Minimum Spanning Trees Problem: Connect a set of nodes by a network of minimal total length Some applications: –Communication.
Minimum Spanning Trees and Kruskal’s Algorithm CLRS 23.
1 Minimum Spanning Trees. Minimum- Spanning Trees 1. Concrete example: computer connection 2. Definition of a Minimum- Spanning Tree.
1 Greedy Algorithms and MST Dr. Ying Lu RAIK 283 Data Structures & Algorithms.
Chapter 24: Single-Source Shortest Paths Given: A single source vertex in a weighted, directed graph. Want to compute a shortest path for each possible.
November 13, Algorithms and Data Structures Lecture XII Simonas Šaltenis Aalborg University
Chapter 23: Minimum Spanning Trees: A graph optimization problem Given undirected graph G(V,E) and a weight function w(u,v) defined on all edges (u,v)
F d a b c e g Prim’s Algorithm – an Example edge candidates choosen.
Finding Minimum Spanning Trees Algorithm Design and Analysis Week 4 Bibliography: [CLRS]- Chap 23 – Minimum.
© 2007 Seth James Nielson Minimum Spanning Trees … or how to bring the world together on a budget.
Greedy Algorithms Z. GuoUNC Chapel Hill CLRS CH. 16, 23, & 24.
1 22c:31 Algorithms Minimum-cost Spanning Tree (MST)
© 2007 Seth James Nielson Minimum Spanning Trees … or how to bring the world together on a budget.
1 Week 3: Minimum Spanning Trees Definition of MST Generic MST algorithm Kruskal's algorithm Prim's algorithm.
MST Lemma Let G = (V, E) be a connected, undirected graph with real-value weights on the edges. Let A be a viable subset of E (i.e. a subset of some MST),
Lecture 12 Algorithm Analysis Arne Kutzner Hanyang University / Seoul Korea.
Minimum Spanning Trees Problem Description Why Compute MST? MST in Unweighted Graphs MST in Weighted Graphs –Kruskal’s Algorithm –Prim’s Algorithm 1.
Algorithm Design and Analysis June 11, Algorithm Design and Analysis Pradondet Nilagupta Department of Computer Engineering This lecture note.
Minimum Spanning Tree. p2. Minimum Spanning Tree G=(V,E): connected and undirected w: E  R, weight function a b g h i c f d e
Midwestern State University Minimum Spanning Trees Definition of MST Generic MST algorithm Kruskal's algorithm Prim's algorithm 1.
November 22, Algorithms and Data Structures Lecture XII Simonas Šaltenis Nykredit Center for Database Research Aalborg University
Greedy Algorithms General principle of greedy algorithm
Lecture ? The Algorithms of Kruskal and Prim
Introduction to Algorithms
Minimum Spanning Trees
Spanning Trees Kruskel’s Algorithm Prim’s Algorithm
Minimum Spanning Trees
Lecture 12 Algorithm Analysis
CISC 235: Topic 10 Graph Algorithms.
Minimum Spanning Tree.
Algorithms and Data Structures Lecture XII
Data Structures – LECTURE 13 Minumum spanning trees
CS 583 Analysis of Algorithms
Lecture 12 Algorithm Analysis
Minimum Spanning Tree Algorithms
Minimum Spanning Trees
Greedy Algorithms Comp 122, Spring 2004.
Lecture 12 Algorithm Analysis
Total running time is O(E lg E).
Advanced Algorithms Analysis and Design
Chapter 23: Minimum Spanning Trees: A graph optimization problem
Minimum Spanning Trees
Presentation transcript:

MST Many of the slides are from Prof. Plaisted’s resources at University of North Carolina at Chapel Hill

Motivation: Minimum Spanning Trees  To minimize the length of a connecting network, it never pays to have cycles.  The resulting connection graph is connected, undirected, and acyclic, i.e., a free tree (sometimes called simply a tree).  This is the minimum spanning tree or MST problem.

Formal Definition of MST  Given a connected, undirected, graph G = (V, E), a spanning tree is an acyclic subset of edges T  E that connects all the vertices together.  Assuming G is weighted, we define the cost of a spanning tree T to be the sum of edge weights in the spanning tree w(T) =  (u,v)  T w(u,v)  A minimum spanning tree (MST) is a spanning tree of minimum weight.

Figure1 : Examples of MST  Not only do the edges sum to the same value, but the same set of edge weights appear in the two MSTs. NOTE: An MST may not be unique.

Steiner Minimum Trees (SMT)  Given a undirected graph G = (V, E) with edge weights and a subset of vertices V’  V, called terminals. We wish to compute a connected acyclic subgraph of G that includes all terminals. MST is just a SMT with V’ =V. Figure 2: Steiner Minimum Tree

Generic Approaches  Two greedy algorithms for computing MSTs: »Kruskal’s Algorithm »Prim’s Algorithm

Facts about (Free) Trees  A tree with n vertices has exactly n-1 edges (|E| = |V| - 1)  There exists a unique path between any two vertices of a tree  Adding any edge to a tree creates a unique cycle; breaking any edge on this cycle restores a tree For details see CLRS Appendix B.5

Intuition Behind Greedy MST  We maintain in a subset of edges A, which will initially be empty, and we will add edges one at a time, until equals the MST. We say that a subset A  E is viable if A is a subset of edges in some MST. We say that an edge (u,v)  E-A is safe if A  {(u,v)} is viable.  Basically, the choice (u,v) is a safe choice to add so that A can still be extended to form an MST. Note that if A is viable it cannot contain a cycle. A generic greedy algorithm operates by repeatedly adding any safe edge to the current spanning tree.

Generic-MST (G, w) 1. A   // A trivially satisfies invariant // lines 2-4 maintain the invariant 2. while A does not form a spanning tree 3. do find an edge (u,v) that is safe for A 4. A  A  {(u,v)} 5. return A // A is now a MST

Definitions  A cut (S, V-S) is just a partition of the vertices into 2 disjoint subsets. An edge (u, v) crosses the cut if one endpoint is in S and the other is in V-S. Given a subset of edges A, we say that a cut respects A if no edge in A crosses the cut.  An edge of E is a light edge crossing a cut, if among all edges crossing the cut, it has the minimum weight (the light edge may not be unique if there are duplicate edge weights).

When is an Edge Safe?  If we have computed a partial MST, and we wish to know which edges can be added that do NOT induce a cycle in the current MST, any edge that crosses a respecting cut is a possible candidate.  Intuition says that since all edges crossing a respecting cut do not induce a cycle, then the lightest edge crossing a cut is a natural choice.

MST Lemma  Let G = (V, E) be a connected, undirected graph with real-value weights on the edges. Let A be a viable subset of E (i.e. a subset of some MST), let (S, V-S) be any cut that respects A, and let (u,v) be a light edge crossing this cut. Then, the edge is safe for A.

Proof of MST Lemma  Must show that A  {(u,v)} is a subset of some MST  Method: 1.Find arbitrary MST T containing A 2.Use a cut-and-paste technique to find another MST T that contains A  {(u,v)}  This cut-and-paste idea is an important proof technique

Figure Figure 3: MST Lemma

Step 1  Let T be any MST for G containing A. »We know such a tree exists because A is viable.  If (u, v) is in T then we are done.

Constructing T’  If (u, v) is not in T, then add it to T, thus creating a cycle. Since u and v are on opposite sides of the cut, and since any cycle must cross the cut an even number of times, there must be at least one other edge (x, y) in T that crosses the cut.  The edge (x, y) is not in A (because the cut respects A). By removing (x,y) we restore a spanning tree, T’.  Now must show »T’ is a minimum spanning tree »A  {(u,v)} is a subset of T’

Conclusion of Proof  T’ is an MST: We have w(T’) = w(T) - w(x,y) + w(u,v) Since (u,v) is a light edge crossing the cut, we have w(u,v)  w(x,y). Thus w(T’)  w(T). So T’ is also a minimum spanning tree.  A  {(u,v)}  T’: Remember that (x, y) is not in A. Thus A  T - {(x, y)}, and thus A  {(u,v)}  T - {(x, y)}  {(u,v)} = T’

MST Lemma: Reprise  Let G = (V, E) be a connected, undirected graph with real-value weights on the edges. Let A be a viable subset of E (i.e. a subset of some MST), let (S, V-S) be any cut that respects A, and let (u,v) be a light edge crossing this cut. Then, the edge is safe for A.  Point of Lemma: Greedy strategy works!

Basics of Kruskal’s Algorithm  Attempts to add edges to A in increasing order of weight (lightest edge first) »If the next edge does not induce a cycle among the current set of edges, then it is added to A. »If it does, then this edge is passed over, and we consider the next edge in order. »As this algorithm runs, the edges of A will induce a forest on the vertices and the trees of this forest are merged together until we have a single tree containing all vertices.

Detecting a Cycle  We can perform a DFS on subgraph induced by the edges of A, but this takes too much time.  Use “disjoint set UNION-FIND” data structure. This data structure supports 3 operations: Create-Set(u): create a set containing u. Find-Set(u): Find the set that contains u. Union(u, v): Merge the sets containing u and v. Each can be performed in O(lg n) time.  The vertices of the graph will be elements to be stored in the sets; the sets will be vertices in each tree of A (stored as a simple list of edges).

MST-Kruskal(G, w) 1. A   // initially A is empty 2. for each vertex v  V[G] // line 2-3 takes O(|V|) time 3. do Create-Set(v)// create set for each vertex 4. sort the edges of E by nondecreasing weight w 5. for each edge (u,v)  E, in order by nondecreasing weight 6. do if Find-Set(u)  Find-Set(v) // u&v on different trees 7. then A  A  {(u,v)} 8. Union(u,v) 9. return A Total running time is O(|E| lg |E|)=O(|E| lg |V|).

Example: Kruskal’s Algorithm Figure 4: Kruskal’s Algorithm

Analysis of Kruskal  Lines 1-3 (initialization): O(V)  Line 4 (sorting): O(E lg E)  Lines 6-8 (set-operation): O(E log E)  Total: O(E log E)

Correctness of Kruskal  Idea: Show that every edge added is a safe edge for A  Assume (u, v) is next edge to be added to A. »Will not create a cycle  Let A’ denote the tree of the forest A that contains vertex u. Consider the cut (A’, V-A’). »This cut respects A (why?) »and (u, v) is the light edge across the cut (why?)  Thus, by the MST Lemma, (u,v) is safe.

Intuition behind Prim’s Algorithm  Consider the set of vertices S currently part of the tree, and its complement (V-S). We have a cut of the graph and the current set of tree edges A is respected by this cut.  Which edge should we add next? Light edge!

Basics of Prim ’s Algorithm  It works by adding leaves on at a time to the current tree. »Start with the root vertex r (it can be any vertex). At any time, the subset of edges A forms a single tree. S = vertices of A. »At each step, a light edge connecting a vertex in S to a vertex in V- S is added to the tree. »The tree grows until it spans all the vertices in V.  Implementation Issues: »How to update the cut efficiently? »How to determine the light edge quickly?

Implementation: Priority Queue  Priority queue implemented using min-heap can support the following operations in O(lg n) time: »Insert (Q, u, key): Insert u with the key value key in Q » u = Extract_Min(Q): Extract the item with minimum key value in Q »Decrease_Key(Q, u, new_key): Decrease the value of u’s key value to new_key  All the vertices that are not in the S (the vertices of the edges in A) reside in a priority queue Q based on a key field. When the algorithm terminates, Q is empty. A = {(v,  [v]): v  V - {r}}

Example: Prim’s Algorithm

MST-Prim(G, w, r) 1. Q  V[G] 2. for each vertex u  Q// initialization: O(V) time 3. do key[u]   4. key[r]  0// start at the root 5.  [r]  NIL// set parent of r to be NIL 6. while Q   // until all vertices in MST 7. do u  Extract-Min(Q) // vertex with lightest edge 8. for each v  adj[u] 9. do if v  Q and w(u,v) < key[v] 10. then  [v]  u 11. key[v]  w(u,v) // new lighter edge out of v 12. decrease_Key(Q, v, key[v])

Analysis of Prim  Extracting the vertex from the queue: O(lg |V|)  For each incident edge, decreasing the key of the neighboring vertex: O(lg |V|)  The other steps are constant time.  The overall running time is, where T(n) =  u  V (lg |V| + deg(u) lg |V|) =  u  V (1+ deg(u)) lg |V| = lg |V| (|V| + 2|E|) = O(|E| lg |V|) Essentially same as Kruskal’s If use Fibonacci Heap, O(|E| + |V| lg |V|).

Correctness of Prim  Again, show that every edge added is a safe edge for A  Assume (u, v) is next edge to be added to A.  Consider the cut (A, V-A). »This cut respects A (why?) »and (u, v) is the light edge across the cut (why?)  Thus, by the MST Lemma, (u,v) is safe.