类 BoruvkaMST
- java.lang.Object
-
- edu.princeton.cs.algs4.BoruvkaMST
-
public class BoruvkaMST extends java.lang.Object
TheBoruvkaMST
class represents a data type for computing a minimum spanning tree in an edge-weighted graph. The edge weights can be positive, zero, or negative and need not be distinct. If the graph is not connected, it computes a minimum spanning forest, which is the union of minimum spanning trees in each connected component. Theweight()
method returns the weight of a minimum spanning tree and theedges()
method returns its edges.This implementation uses Boruvka's algorithm and the union-find data type. The constructor takes time proportional to E log V and extra space (not including the graph) proportional to V, where V is the number of vertices and E is the number of edges. Afterwards, the
weight()
method takes constant time and theedges()
method takes time proportional to V.For additional documentation, see Section 4.3 of Algorithms, 4th Edition by Robert Sedgewick and Kevin Wayne. For alternate implementations, see
LazyPrimMST
,PrimMST
, andKruskalMST
.
-
-
构造器概要
构造器 构造器 说明 BoruvkaMST(EdgeWeightedGraph G)
Compute a minimum spanning tree (or forest) of an edge-weighted graph.
-
-
-
构造器详细资料
-
BoruvkaMST
public BoruvkaMST(EdgeWeightedGraph G)
Compute a minimum spanning tree (or forest) of an edge-weighted graph.- 参数:
G
- the edge-weighted graph
-
-
方法详细资料
-
edges
public java.lang.Iterable<Edge> edges()
Returns the edges in a minimum spanning tree (or forest).- 返回:
- the edges in a minimum spanning tree (or forest) as an iterable of edges
-
weight
public double weight()
Returns the sum of the edge weights in a minimum spanning tree (or forest).- 返回:
- the sum of the edge weights in a minimum spanning tree (or forest)
-
main
public static void main(java.lang.String[] args)
Unit tests theBoruvkaMST
data type.- 参数:
args
- the command-line arguments
-
-