最小生成树问题
描述:给出一个连通无向图 G = ( u , v ) G=(u,v) G=(u,v)和边权重函数 w : E → R w:E→R w:E→R,希望找出它的最小生成树,即找出一个无环子集使得所有结点都被连接且边权之和最短。
生成过程
MST(G,w)
initialize A with empty set
while A doesn't form a MST
find an edge (u,v) that is safe for A
A = A union {
(u,v)}
return A
其中A是某个最小生成树的子集,边(u,v)对A安全意味着A并边(u,v)仍然是某个最小生成树的子集。
辨认安全边的规则
首先提出切割的定义
切割
- 无向图