structure
Class ComparableEdge
java.lang.Object
|
+--structure.Edge
|
+--structure.ComparableEdge
- All Implemented Interfaces:
- Comparable
- public class ComparableEdge
- extends Edge
- implements Comparable
A class implementing common edge type among graphs. This class
supports both directed and undirected edges. Edge may also have
visited flags set and cleared. ComparableEdge differs from
edge, however, in that it requires that its lable be of a comparable
type.
Typical usage:
Graph g = new GraphListDirected();
g.add("harry");
g.add("sally");
g.addEdge("harry","sally","friendly");
ComparableEdge e = new ComparableEdge(g.getEdge("harry","sally"))
;
Comparable label = e.label()
;
Vertex source = e.here()
;
Vertex destination = e.there()
;
ComparableEdge e2 = e;
if(e.compareTo(e2)
== 0){
e.visit()
;
e.reset()
;
}
...
- See Also:
Graph
ComparableEdge
public ComparableEdge(Object vtx1,
Object vtx2,
Object label,
boolean directed)
- Construct a (possibly directed) edge between two labeled
vertices. When edge is directed, vtx1 specifies source.
When undirected, order of vertices is unimportant. Label
on edge is any type, and may be null.
Edge is initially unvisited.
- Parameters:
vtx1
- The label of a vertex (source if directed).vtx2
- The label of another vertex (destination if directed).label
- The label associated with the edge.directed
- True iff this edge is directed.
ComparableEdge
public ComparableEdge(Edge e)
- Construct a (possibly directed) edge between two labeled
vertices. When edge is directed, vtx1 specifies source.
When undirected, order of vertices is unimportant. Label
on edge is any type, and may be null.
Edge is initially unvisited.
- Parameters:
e
- The edge to be used as the basis for a comparable edge
compareTo
public int compareTo(Object other)
- Compare edge, based on labels.
- Specified by:
compareTo
in interface Comparable
- Precondition:
- labels are Comparable
- Postcondition:
- returns integer representing relation between labels
toString
public String toString()
- Construct a string representation of edge.
- Overrides:
toString
in class Edge
- Postcondition:
- returns string representation of edge
- Returns:
- String representing edge.