Minimum Spanning Trees
Table of Contents
1 Reading
Read Algorithms 4.3
2 Video
Here is a video lecture for the slides below.
The video contains sections on
- Spanning Trees (0:21)
- Observations (1:04)
- Motivation (2:30)
- Two Approaches (5:00)
- Spanning tree via DFS (6:05)
- Second Approach (9:57)
- Example (10:51)
- Cycle Detection (12:06)
- Summary So Far (14:48)
- Getting to the Point (16:25)
- Prim's Algorithm Idea (17:24)
- Prim's Example (19:48)
- Analysis (24:29)
- Kruskal's Algorithm (25:10)
- Pseudocode (28:41)
- Kruskal's Example (29:58)
The Panopto viewer has table of contents entries for these sections: https://carleton.hosted.panopto.com/Panopto/Pages/Viewer.aspx?id=e24bd70f-e78d-4275-bc5f-ace00164e3bc
3 Slides
You can download the slides in pdf or PowerPoint.
4 Practice Problems1
- What is a spanning tree of a graph?
- What is a minimum spanning tree of a weighted graph?
- Under what conditions can a graph have nonunique minimum spanning trees?
- How would you find a maximum spanning tree of an edge-weighted graph?
- Given an MST for an edge-weighted graph \(G\), suppose that an edge in \(G\) that does not disconnect \(G\) is deleted. Describe how to find an MST of the new graph in time proportional to \(E\).
- Given an MST for an edge-weighted graph \(G\) and a new edge \(e\), describe how to find an MST of the new graph in time proportional to \(V\).
- Draw a weighted undirected graph with exactly 3 nodes that has exactly 0 minimum spanning trees.
- Draw a weighted undirected graph with exactly 3 nodes that has exactly 1 minimum spanning tree.
- Draw a weighted undirected graph with exactly 3 nodes that has exactly 2 minimum spanning trees.
- Draw a weighted undirected graph with exactly 3 nodes that has exactly 3 minimum spanning trees.
- Can a weighted undirected graph with 3 nodes have more than 3 minimum spanning trees? Why or why not?
 
5 Learning Block
- Summary
- Spanning tree: a subset of edges that connect all the nodes and form no cycles (i.e., a tree that spans the graph)
- Minimum spanning tree: the spanning tree with the minimum total weight
- Two (greedy) algorithms for finding minimum spanning tree
- Prim's
- Like Dijkstra's, incrementally expand a set of known nodes, select the lowest-cost node each time
- Except cost is just the weight of the edge that would bring the node into the spanning tree
- Instead of the cost of the path from source to the unknown node
 
 
- Kruskal's
- Consider edges in order of increasing weight
- Output edge as part of minimum spanning tree if it would not introduce a cycle into spanning tree output so far
- Use union-find data structure to efficiently detect cycles
 
 
- Prim's
 
Footnotes:
1 
Solutions:
- A tree of edges that includes every vertex. Spanning trees are not possible for disconnected graphs; in that case, a spanning forest is required.
- Of all of the spanning trees of a graph, a minimum spanning tree is one whose total edge weight is least.
- There are multiple spanning trees of equal minimum weight.
- Negative the weight of each edge would be one approach.
- If the edge in not in the MST, then the old MST is an MST of the updated graph. Otherwise, deleting the edge from the MST leaves two connected components (i.e., two separate pieces of the graph). Add the minimum weight edge with one vertex in each component.
- Adding edge \(e\) to the MST creates a unique cycle. Delete the maximum weight edge on this cycle.
- Any unconnected, weighted, undirected graph
- Solution needs to have either 2 or 3 non-self edges and if it has 3 non-self edges, then no two can have the same weight
- Graph needs 2 non-self edges, with exactly 2 having the same weight and the third edge having a lower weight
- Graph needs 3 non-self edges, all with the same weight
- A 3-node graph can only have 3 spanning trees because it takes 2 edges (the number of nodes minus 1) to create a spanning tree. If the nodes are A, B, and C, the only possible spanning trees are:
- (A,B), (A,C)
- (B,C), (A,C)
- (A,B), (B,C)