类 Graph
- java.lang.Object
- 
- edu.princeton.cs.algs4.Graph
 
- 
 public class Graph extends java.lang.ObjectTheGraphclass represents an undirected graph of vertices named 0 through V – 1. It supports the following two primary operations: add an edge to the graph, iterate over all of the vertices adjacent to a vertex. It also provides methods for returning the number of vertices V and the number of edges E. Parallel edges and self-loops are permitted. By convention, a self-loop v-v appears in the adjacency list of v twice and contributes two to the degree of v.This implementation uses an adjacency-lists representation, which is a vertex-indexed array of Bagobjects. All operations take constant time (in the worst case) except iterating over the vertices adjacent to a given vertex, which takes time proportional to the number of such vertices.For additional documentation, see Section 4.1 of Algorithms, 4th Edition by Robert Sedgewick and Kevin Wayne. 
- 
- 
方法概要修饰符和类型 方法 说明 voidaddEdge(int v, int w)Adds the undirected edge v-w to this graph.java.lang.Iterable<java.lang.Integer>adj(int v)Returns the vertices adjacent to vertexv.intdegree(int v)Returns the degree of vertexv.intE()Returns the number of edges in this graph.static voidmain(java.lang.String[] args)Unit tests theGraphdata type.java.lang.StringtoString()Returns a string representation of this graph.intV()Returns the number of vertices in this graph.
 
- 
- 
- 
构造器详细资料- 
Graphpublic Graph(int V) Initializes an empty graph withVvertices and 0 edges. param V the number of vertices- 参数:
- V- number of vertices
- 抛出:
- java.lang.IllegalArgumentException- if- V < 0
 
 - 
Graphpublic Graph(In in) Initializes a graph from the specified input stream. The format is the number of vertices V, followed by the number of edges E, followed by E pairs of vertices, with each entry separated by whitespace.- 参数:
- in- the input stream
- 抛出:
- java.lang.IllegalArgumentException- if the endpoints of any edge are not in prescribed range
- java.lang.IllegalArgumentException- if the number of vertices or edges is negative
- java.lang.IllegalArgumentException- if the input stream is in the wrong format
 
 - 
Graphpublic Graph(Graph G) Initializes a new graph that is a deep copy ofG.- 参数:
- G- the graph to copy
 
 
- 
 - 
方法详细资料- 
Vpublic int V() Returns the number of vertices in this graph.- 返回:
- the number of vertices in this graph
 
 - 
Epublic int E() Returns the number of edges in this graph.- 返回:
- the number of edges in this graph
 
 - 
addEdgepublic void addEdge(int v, int w)Adds the undirected edge v-w to this graph.- 参数:
- v- one vertex in the edge
- w- the other vertex in the edge
- 抛出:
- java.lang.IllegalArgumentException- unless both- 0 <= v < Vand- 0 <= w < V
 
 - 
adjpublic java.lang.Iterable<java.lang.Integer> adj(int v) Returns the vertices adjacent to vertexv.- 参数:
- v- the vertex
- 返回:
- the vertices adjacent to vertex v, as an iterable
- 抛出:
- java.lang.IllegalArgumentException- unless- 0 <= v < V
 
 - 
degreepublic int degree(int v) Returns the degree of vertexv.- 参数:
- v- the vertex
- 返回:
- the degree of vertex v
- 抛出:
- java.lang.IllegalArgumentException- unless- 0 <= v < V
 
 - 
toStringpublic java.lang.String toString() Returns a string representation of this graph.- 覆盖:
- toString在类中- java.lang.Object
- 返回:
- the number of vertices V, followed by the number of edges E, followed by the V adjacency lists
 
 - 
mainpublic static void main(java.lang.String[] args) Unit tests theGraphdata type.- 参数:
- args- the command-line arguments
 
 
- 
 
-