7.1. Implementation
This section describes how to implement a graph structure.
Last updated
Was this helpful?
This section describes how to implement a graph structure.
Last updated
Was this helpful?
There are several types of graphs:
Can we represent undirected graphs using an implementation of directed graphs?
L2-3
: the source and target vertices are represented by unique IDs in int
.
L10
: constructor overwriting.
L14
: copy constructor.
Let us the define the init()
method, getters, and setters:
Let us override the compareTo()
method that compares this edge to another edge by their weights:
L4
: returns 1
if the weight of this edge is greater.
L5
: returns -1
if the weight of the other edge is greater.
L6
: returns 0
is the weights of both edges are the same.
L2
: a list of edge lists where each dimension of the outer list indicates a target vertex and the inner list corresponds to the list of incoming edges to that target vertex.
L5
: creates an empty edge list for each target vertex.
L9
: copies the list of edge lists from g
to this graph.
L17
: the size of the graph is the number of vertices in the graph.
For example, a graph with 3 vertices 0
, 1
, and 2
and 3 edges 0 -> 1
, 2 -> 1
, and 0 -> 2
, the incoming_edges
is as follows:
Let us define setters for edges:
L2-4
: retrieves the incoming edge list of target
, and adds the new edge to the edge list.
L9-10
: add edges to both directions.
Let us then define getters:
What is the worst-case complexity of the
getVerticesWithNoIncomingEdges()
method?
Let us define the getOutgoingEdges()
method that returns the list of outgoing edges:
L1
: returns a list of edge deque, where each dimension in the outer list represents the deque of outgoing edges for the corresponding source vertex.
L2
: generates the list of empty edge deques.
L4-7
: visits every target vertex to retrieve the incoming edge lists, and assigns edges to appropriate source vertices.
What is the worst-case complexity of the
getOutgoingEdges()
method?
Let us create the class representing a directed edge under the package:
L1
: inherits the interface.
Let us create the class under the package:
L13
: returns true if all incoming edge lists are empty using the method.
L6
: uses the method that merges the list of edge lists into one list of edges.
L10
: uses the and methods to find vertices with no incoming edges.