22
Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs) What is a Minimum Spanning Tree? Constructing Minimum Spanning Trees. What is a Minimum-Cost Spanning Tree (MCST) ? Applications of Minimum Cost Spanning Trees. MCST Algorithms: Kruskal’s Algorithm. Tracing Kruskal’s Algorithm • Implementation. Prim’s algorithm. Tracing Prim’s Algorithm • Implementation. Review Questions.

Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

  • Upload
    deacon

  • View
    95

  • Download
    2

Embed Size (px)

DESCRIPTION

Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs). What is a Minimum Spanning Tree? Constructing Minimum Spanning Trees. What is a Minimum-Cost Spanning Tree (MCST) ? Applications of Minimum Cost Spanning Trees. MCST Algorithms: Kruskal’s Algorithm. - PowerPoint PPT Presentation

Citation preview

Page 1: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

1

Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

• What is a Minimum Spanning Tree?

• Constructing Minimum Spanning Trees.

• What is a Minimum-Cost Spanning Tree (MCST) ?

• Applications of Minimum Cost Spanning Trees.

• MCST Algorithms:– Kruskal’s Algorithm.

• Tracing Kruskal’s Algorithm• Implementation.

– Prim’s algorithm.• Tracing Prim’s Algorithm• Implementation.

• Review Questions.

Page 2: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

2

What is a Minimum Spanning Tree?• Let G = (V, E) be a simple, connected, undirected graph that is not

edge-weighted.

• A spanning tree of G is a free tree (i.e., a tree with no root) with | V | - 1 edges that connects all the vertices of the graph.

• Thus a minimum spanning tree T = (V’, E’) for G is a subgraph of G with the following properties: V’ = V T is connected T is acyclic ( |E’| = |V| - 1)

• A spanning tree is called a tree because every acyclic undirected graph can be viewed as a general, unordered tree. Because the edges are undirected, any vertex may be chosen to serve as the root of the tree.

Page 3: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

3

Constructing Minimum Spanning Trees• Any traversal of a connected, undirected graph

visits all the vertices in that graph. The set of edges which are traversed during a traversal forms a spanning tree.

• For example, Fig (b) shows a spanning tree of G obtained from a breadth-first traversal starting at vertex a.

• Similarly, Fig (c) shows a spanning tree of G obtained from a depth-first traversal starting at vertex c.

)a (Graph G

(b) Breadth-first spanning tree of G starting from a

(c) Depth-first spanning tree of G starting from c

Page 4: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

4

What is a Minimum-Cost Spanning Tree?• For an edge-weighted , connected, undirected graph, G, the total

cost of G is the sum of the weights on all its edges.• A minimum-cost spanning tree for G is a minimum spanning tree of

G that has the least total cost.• Example: The graph

Has 16 spanning trees. Some are:

The graph has two minimum-cost spanning trees, each with a cost of 6:

Page 5: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

5

Applications of Minimum-Cost Spanning Trees

Minimum-cost spanning trees have many applications. Some are:• Building cable networks that join n locations with minimum cost.• Building a road network that joins n cities with minimum cost.• Obtaining an independent set of circuit equations for an electrical

network.• In pattern recognition minimal spanning trees can be used to find noisy

pixels.

Page 6: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

6

MCST Algorithms: Kruskal's AlgorithmKruskal’s algorithm finds the minimum cost spanning tree of a graph by adding edges one-by-one to an initially empty free tree

enqueue edges of G in a queue in increasing order of cost.T = ;while(queue is not empty){ dequeue an edge e; if(e does not create a cycle with edges in T) add e to T;}return T;

Running time is O(E log V)

Page 7: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

7

Tracing Kruskal’s AlgorithmTrace Kruskal's algorithm in finding a minimum-cost spanning tree for the undirected, weighted graph given below:

The minimum cost is: 24

Page 8: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

8

Implementation of Kruskal's Algorithmpublic static Graph kruskalsAlgorithm(Graph g){ Graph result = new GraphAsLists(false); Iterator it = g.getVertices(); while (it.hasNext()){ Vertex v = (Vertex)it.next(); result.addVertex(v.getLabel()); } PriorityQueue queue = new BinaryHeap(g.getNumberOfEdges()); it = g.getEdges(); while(it.hasNext()){ Edge e = (Edge) it.next(); if (e.getWeight()==null) throw new IllegalArgumentException("Graph is not weighted"); queue.enqueue(e); } while (!queue.isEmpty()){ // test if there is a path from vertex // from to vertex to before adding the edge Edge e = (Edge) queue.dequeueMin(); String from = e.getFromVertex().getLabel(); String to = e.getToVertex().getLabel(); if (!result.isReachable(from, to)) result.addEdge(from,to,e.getWeight()); } return result;}

adds an edge only, if it does not create a cycle

Page 9: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

9

Implementation of Kruskal's Algorithm (Cont’d)public abstract class AbstractGraph implements Graph { public boolean isReachable(String from, String to){ Vertex fromVertex = getVertex(from); Vertex toVertex = getVertex(to); if (fromVertex == null || toVertex==null) throw new IllegalArgumentException("Vertex not in the graph"); PathVisitor visitor = new PathVisitor(toVertex); this.preorderDepthFirstTraversal(visitor, fromVertex); return visitor.isReached(); }

private class PathVisitor implements Visitor { boolean reached = false; Vertex target; PathVisitor(Vertex t){target = t;}

public void visit(Object obj){ Vertex v = (Vertex) obj; if (v.equals(target)) reached = true; } public boolean isDone(){return reached;} boolean isReached(){return reached;} }}

Page 10: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

10

MCST Algorithms: Prim’s AlgorithmThe algorithm continuously increases the size of a tree starting with a single vertex until it spans all the vertices of G:

Consider a weighted, connected, undirected graph G=(V, E) and a free tree T = (VT, ET) that is a subgraph of G

Initialize: VT = {x}; // where x is an arbitrary vertex from VInitialize: ET = ;repeat{

Choose an edge (v,w) with minimal weight such that v is in VT and w is not (if there are multiple edges with the same weight, choose arbitrarily but consistently); // add an minimal weight edge that will not form a cycle Add vertex v to VT; add edge (v, w) to ET;

}until (VT == V);

Graph and Minimum edge weight data structureTime complexity (total)

adjacency matrix and array O(V2)

adjacency list and binary heapO((V + E) log(V)) = O(E log(V))

Adjacency list and Fibonacci heapO(E + V log(V))

Time Complexity of Prim’s Algorithm:

Page 11: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

11

Tracing Prim’s Algorithm (Example adopted from Wikipedia)

We want to find a Minimum Cost Spanning Tree for the graph on the left. The numbers near the edges indicate the edge weights.

Vertex D has been arbitrarily chosen as a starting point. Vertices A, B, E and F are connected to D through a single edge. A is the vertex nearest to D and will be chosen as the second vertex along with the edge AD.

The next vertex chosen is the vertex nearest to either D or A. B is 9 away from D and 7 away from A, E is 15, and F is 6. F is the smallest distance away, so we highlight the vertex F and the arc DF.

Page 12: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

12

Tracing Prim’s Algorithm (Cont’d)

The algorithm carries on as above. Vertex B, which is 7 away from A, is highlighted.

In this case, we can choose between C, E, and G. C is 8 away from B, E is 7 away from B, and G is 11 away from F. E is nearest, so we highlight the vertex E and the arc BE.

Here, the only vertices available are C and G. C is 5 away from E, and G is 9 away from E. C is chosen, so it is highlighted along with the arc EC.

Page 13: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

13

Tracing Prim’s Algorithm (Cont’d)

Vertex G is the only remaining vertex. It is 11 away from F, and 9 away from E. E is nearer, so we highlight it and the arc EG.

Now all the vertices have been selected and the minimum cost spanning tree is shown in green. In this case, it has weight 39.

Page 14: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

14

Tracing Prim’s Algorithm: An alternative method

Trace Prim’s algorithm starting at vertex a:

The resulting minimum-cost spanning tree is:

Note: Current Active vertex is vertex in the row with minimum weight from the previous column, v1 is the active vertex in the column where weight appears for the first time

Page 15: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

15

Implementation of Prim’s Algorithm using MinHeap

• The implementation of Prim's algorithm uses an Entry class, which contains the following three fields:

– know: a boolean variable indicating whether the weight of the edge from this vertex to an active vertex v1 is known, initially false for all vertices.

– weight : the minimum known weight from this vertex to an active vertex v1, initially infinity for all vertices except that of the starting vertex which is 0.

– predecessor : the predecessor of an active vertex v1 in the MCST, initially unknown for all vertices.

public class Algorithms{ static final class Entry{ boolean known; int weight; Vertex predecessor;

Entry(){ known = false; weight = Integer.MAX_VALUE; predecessor = null; } }

Page 16: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

16

Implementation of Prim’s Algorithm using MinHeap (Cont’d)

make a table of values (known, weight(edge), predecessor) initially (FALSE,,null) for each vertex except the start vertex table entry is set to (FALSE, 0, null) ;MinHeap = ;MinHeap.enqueue( Association (0, startVertex)); // let tree T be empty; while (MinHeap is not empty) { // T has fewer than n vertices dequeue an Association (weight(e), v) from the MinHeap; Update table entry for v to (TRUE, weight(e), v); // add v and e to T for( each emanating edge f = (v, u) of v){ if( table[u].known == FALSE ) // u is not already in T if (weight(f) < table[u].weight) { // find the current min edge weight table[u].weight = weight(f); table[u].predecessor = v; enqueue(Association(weight(f), u); } } }}

The idea is to use a table array to remember, for each vertex, the smallest edge connecting T with that vertex. Each entry in table represents a vertex x. The object stored at table entry index(x) will have the predecessor of x and the corresponding edge weight.

Page 17: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

17

Implementation of Prim’s Algorithm using MinHeap (Cont’d)

Prim’s algorithm can be implemented as shown below:

public static Graph primsAlgorithm(Graph g, Vertex start){ int n = g.getNumberOfVertices(); Entry table[] = new Entry[n]; for(int v = 0; v < n; v++) table[v] = new Entry();

table[g.getIndex(start)].weight = 0; PriorityQueue queue = new BinaryHeap(g.getNumberOfEdges()); queue.enqueue(new Association(new Integer(0), start)); while(!queue.isEmpty()) { Association association = (Association)queue.dequeueMin(); Vertex v1 = (Vertex) association.getValue(); int n1 = g.getIndex(v1); if(!table[n1].known){ table[n1].known = true; Iterator p = v1.getEmanatingEdges(); while (p.hasNext()){ Edge edge = (Edge) p.next(); Vertex v2 = edge.getMate(v1); int n2 = g.getIndex(v2); Integer weight = (Integer) edge.getWeight(); int d = weight.intValue();

Page 18: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

18

Implementation of Prim’s Algorithm using MinHeap (Cont'd)

if(!table[n2].known && d < table[n2].weight){ table[n2].weight = d; table[n2].predecessor = v1; queue.enqueue(new Association(new Integer(d), v2)); } } } } GraphAsLists result = new GraphAsLists(false); Iterator it = g.getVertices(); //add vertices of this graph to result while (it.hasNext()){ Vertex v = (Vertex) it.next(); result.addVertex(v.getLabel()); } // add edges to result using each vertex predecessor in table it = g.getVertices(); while (it.hasNext()){// Vertex v = (Vertex) it.next(); if (v != start){ int index = g.getIndex(v); String from = v.getLabel(); String to = table[index].predecessor.getLabel(); result.addEdge(from, to, new Integer(table[index].distance)); } } return result;}

Page 19: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

19

Tracing Prim’s Algorithm from the MinHeap implementation

A

D

E

B

C

3 0 52 0

69

21 2

6

A B C D E0 1 2 3 4

T0

n u ll

F3 0A

F2A

F9A

F

n u ll

ta bleque uef ro n t re a r

2C

9D

3 0B

A B C D E0 1 2 3 4

F0

n u ll

F

n u ll

F

n u ll

F

n u ll

F

n u ll

ta bleque uef ro n t re a r

0A

Trace Prim’s algorithm in finding a MCST starting from vertex A:

A B C D E0 1 2 3 4

T0

n u ll

F5C

T2A

F6C

F6C

ta bleque uef ro n t re a r

6D

5B

6E

3 0B

9D

Enqueue edge weights for edges emanating from A

Enqueue edge weights for edges emanating from C

Page 20: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

20

Tracing Prim’s Algorithm from the MinHeap implementation (Cont’d)

A B C D E0 1 2 3 4

T0

n u ll

T5C

T2A

F6C

F6C

ta bleque uef ro n t re a r

6E

6D

3 0B

9D

A B C D E0 1 2 3 4

T0

n u ll

T5C

T2A

T6C

F6C

ta bleque uef ro n t re a r

9D

6E

3 0B

A B C D E0 1 2 3 4

T0

n u ll

T5C

T2A

T6C

T6C

ta bleque uef ro n t re a r

A

D

E

B

C

3 0 52 0

69

21 2

6

A

D

E

B

C

5

6

2 6

The MCST:

Page 21: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

21

Note on MCSTs generated by Prim’s and Kruskal’s Algorithms

Note: It is not necessary that Prim's and Kruskal's algorithm generate the same minimum-cost spanning tree.For example for the graph:

Kruskal's algorithm (that imposes an ordering on edges with equal weights) results in the following minimum cost spanning tree:

The same tree is generated by Prim's algorithm if the start vertex is any of: A, B, or D; however if the start vertex is C the minimum cost spanning tree is:

Page 22: Minimum Spanning Trees (MSTs) and Minimum Cost Spanning Trees (MCSTs)

22

Review Questions

1. Find the breadth-first spanning tree and depth-first spanning tree of the graph GA shown above.

2. For the graph GB shown above, trace the execution of Prim's algorithm as it finds the minimum-cost spanning tree of the graph starting from vertex a.

3. Repeat question 2 above using Kruskal's algorithm.

GB