© 1998-2002 McGraw-Hill

structure
Interface Graph

All Superinterfaces:
Structure
All Known Implementing Classes:
GraphList, GraphMatrix

public interface Graph
extends Structure

The interface describing all Graph objects. Graphs are collections of vertices connected by a set of edges. Edges may or may not be directed. Portions of the graph may be marked visited to support iterative algorithms. Iteration is provided over vertices, edges, and vertices adjacent to a particular vertex

Example usage:

To visit all of the vertices reachable from a given vertex we could use the following:

   static void reachableFrom(Graph g, Object vertexLabel)
   {
	 g.visit(vertexLabel);	// visit this vertex

	 // recursively visit unvisited neighbor vertices
	 Iterator ni = g.neighbors(vertexLabel);
	 while (ni.hasNext())
	 {
	     Object neighbor = ni.next(); // adjacent node label
	     if (!g.isVisited(neighbor)x)
	     {
		 reachableFrom(g,neighbor); // depth-first search
	     } 
	 }
   }
 

See Also:
GraphList, GraphMatrix

Method Summary
 void add(Object label)
          Add a vertex to the graph
 void addEdge(Object vtx1, Object vtx2, Object label)
          Add an edge between two vertices within the graph.
 void clear()
          Remove all vertices (and thus, edges) of the graph.
 boolean contains(Object label)
          Test for vertex membership.
 boolean containsEdge(Object vLabel1, Object vLabel2)
          Test for edge membership.
 int degree(Object label)
          Determine out degree of vertex.
 int edgeCount()
          Determine the number of edges in graph.
 Iterator edges()
          Construct an iterator over all edges.
 Object get(Object label)
          Get reference to actual label of vertex.
 Edge getEdge(Object label1, Object label2)
          Get reference to actual edge.
 boolean isDirected()
          Determine if graph is directed.
 boolean isEmpty()
          Determine if graph is empty.
 boolean isVisited(Object label)
          Return visited flag of vertex.
 boolean isVisitedEdge(Edge e)
          Return visited flag of edge.
 Iterator iterator()
          Construct vertex iterator.
 Iterator neighbors(Object label)
          Construct an adjacent vertex iterator.
 Object remove(Object label)
          Remove a vertex from the graph.
 Object removeEdge(Object vLabel1, Object vLabel2)
          Remove possible edge between vertices labeled vLabel1 and vLabel2.
 void reset()
          Clear visited flags of edges and vertices.
 int size()
          Determine number of vertices within graph.
 boolean visit(Object label)
          Test and set visited flag of vertex
 boolean visitEdge(Edge e)
          Test and set visited flag of edge.
 
Methods inherited from interface structure.Structure
elements, values
 

Method Detail

add

public void add(Object label)
Add a vertex to the graph
Specified by:
add in interface Structure
Parameters:
label - Label of the vertex; should be non-null
Precondition:
label is a non-null label for vertex
Postcondition:
a vertex with label is added to graph if vertex with label is already in graph, no action

addEdge

public void addEdge(Object vtx1,
                    Object vtx2,
                    Object label)
Add an edge between two vertices within the graph. Edge is directed iff graph is directed. Duplicate edges are silently replaced. Labels on edges may be null.
Parameters:
vtx1 - First (or source, if directed) vertex.
vtx2 - Second (or destination, if directed) vertex.
label - Label associated with the edge.
Precondition:
vtx1 and vtx2 are labels of existing vertices
Postcondition:
an edge (possibly directed) is inserted between vtx1 and vtx2.

remove

public Object remove(Object label)
Remove a vertex from the graph. Associated edges are also removed. Non-vertices are silently ignored.
Specified by:
remove in interface Structure
Parameters:
label - The label of the vertex within the graph.
Precondition:
label is non-null vertex label
Postcondition:
vertex with "equals" label is removed, if found
Returns:
The label associated with the vertex.

removeEdge

public Object removeEdge(Object vLabel1,
                         Object vLabel2)
Remove possible edge between vertices labeled vLabel1 and vLabel2. Directed edges consider vLabel1 to be the source.
Parameters:
vLabel1 - First (or source, if directed) vertex.
vLabel2 - Second (or destination, if directed) vertex.
Precondition:
vLabel1 and vLabel2 are labels of existing vertices
Postcondition:
edge is removed, its label is returned
Returns:
The label associated with the edge removed.

get

public Object get(Object label)
Get reference to actual label of vertex. Vertex labels are matched using their equals method, which may or may not test for actual equivalence. Result remains part of graph.
Parameters:
label - The label of the vertex sought.
Postcondition:
returns actual label of indicated vertex
Returns:
The actual label, or null if none is found.

getEdge

public Edge getEdge(Object label1,
                    Object label2)
Get reference to actual edge. Edge is identified by the labels on associated vertices. If edge is directed, the label1 indicates source.
Parameters:
label1 - The first (or source, if directed) vertex.
label2 - The second (or destination, if directed) vertex.
Postcondition:
returns actual edge between vertices
Returns:
The edge, if found, or null.

contains

public boolean contains(Object label)
Test for vertex membership.
Specified by:
contains in interface Structure
Parameters:
label - The label of the vertex sought.
Postcondition:
returns true iff vertex with "equals" label exists
Returns:
True iff vertex with matching label is found.

containsEdge

public boolean containsEdge(Object vLabel1,
                            Object vLabel2)
Test for edge membership. If edges are directed, vLabel1 indicates source.
Parameters:
vLabel1 - First (or source, if directed) vertex.
vLabel2 - Second (or destination, if directed) vertex.
Postcondition:
returns true iff edge with "equals" label exists
Returns:
True iff the edge exists within the graph.

visit

public boolean visit(Object label)
Test and set visited flag of vertex
Parameters:
label - Label of vertex to be visited.
Postcondition:
sets visited flag on vertex, returns previous value
Returns:
Previous value of visited flag on vertex.

visitEdge

public boolean visitEdge(Edge e)
Test and set visited flag of edge.
Parameters:
e - Edge object that is part of graph.
Precondition:
sets visited flag on edge; returns previous value
Returns:
Previous value of the Edge's visited flag.

isVisited

public boolean isVisited(Object label)
Return visited flag of vertex.
Parameters:
label - Label of vertex.
Postcondition:
returns visited flag on labeled vertex
Returns:
True if vertex has been visited.

isVisitedEdge

public boolean isVisitedEdge(Edge e)
Return visited flag of edge.
Parameters:
e - Edge of graph to be considered.
Postcondition:
returns visited flag on edge between vertices
Returns:
True if the edge has been visited.

reset

public void reset()
Clear visited flags of edges and vertices.
Postcondition:
resets visited flags to false

size

public int size()
Determine number of vertices within graph.
Specified by:
size in interface Structure
Postcondition:
returns the number of vertices in graph
Returns:
The number of vertices within graph.

degree

public int degree(Object label)
Determine out degree of vertex.
Parameters:
label - Label associated with vertex.
Precondition:
label labels an existing vertex
Postcondition:
returns the number of vertices adjacent to vertex
Returns:
The number of edges with this vertex as source.

edgeCount

public int edgeCount()
Determine the number of edges in graph.
Postcondition:
returns the number of edges in graph
Returns:
Number of edges in graph.

iterator

public Iterator iterator()
Construct vertex iterator. Vertices are not visited in any guaranteed order.
Specified by:
iterator in interface Structure
Postcondition:
returns iterator across all vertices of graph
Returns:
Iterator traversing vertices in graph.

neighbors

public Iterator neighbors(Object label)
Construct an adjacent vertex iterator. Adjacent vertices (those on destination of edge, if directed) are considered, but not in any guaranteed order.
Parameters:
label - Label of the vertex.
Precondition:
label is label of vertex in graph
Postcondition:
returns iterator over vertices adj. to vertex each edge beginning at label visited exactly once
Returns:
Iterator traversing the adjacent vertices of labeled vertex.

edges

public Iterator edges()
Construct an iterator over all edges. Every directed/undirected edge is considered exactly once. Order is not guaranteed.
Postcondition:
returns iterator across edges of graph iterator returns edges; each edge visited once
Returns:
Iterator over edges.

clear

public void clear()
Remove all vertices (and thus, edges) of the graph.
Specified by:
clear in interface Structure
Postcondition:
removes all vertices from graph

isEmpty

public boolean isEmpty()
Determine if graph is empty.
Specified by:
isEmpty in interface Structure
Postcondition:
returns true if graph contains no vertices
Returns:
True iff there are no vertices in graph.

isDirected

public boolean isDirected()
Determine if graph is directed.
Postcondition:
returns true if edges of graph are directed
Returns:
True iff the graph is directed.

© 1998-2002 McGraw-Hill