📄 kruskalmst.java
字号:
package twf.weightedgraph.undirected;
import java.util.Arrays;
import twf.adt.UF;
import twf.weightedgraph.Edge;
import twf.weightedgraph.EdgeComparator;
import twf.weightedgraph.Graph;
import twf.weightedgraph.common.GraphUtilities;
public class KruskalMST {
private int V;
private UF uf;
private Edge[] a, mst;
public KruskalMST(Graph G)
{ int v, w, E;
E = G.E(); V = G.V();
mst = new Edge[V];
uf = new UF(V);
a = GraphUtilities.edges(G);
Arrays.sort(a, new EdgeComparator());
for (int i = 0, k = 1; i < E && k < V; i++)
if (!uf.find(v = a[i].v(), w = a[i].w()))
{ uf.unite(v, w); mst[k++] = a[i]; }
}
public Edge[] mst() {
return mst;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -