KEMBAR78
Graph Algorithms: Timothy Vismor June 11, 2011 | PDF | Vertex (Graph Theory) | Graph Theory
0% found this document useful (0 votes)
109 views30 pages

Graph Algorithms: Timothy Vismor June 11, 2011

Te network structure of many physical systems is represented by mathematical entities known as graphs. Te document examines several of the computational algorithms of graph theory most relevant to network analysis.

Uploaded by

BodoShow
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
109 views30 pages

Graph Algorithms: Timothy Vismor June 11, 2011

Te network structure of many physical systems is represented by mathematical entities known as graphs. Te document examines several of the computational algorithms of graph theory most relevant to network analysis.

Uploaded by

BodoShow
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 30

Graph Algorithms

Timothy Vismor
June 11, 2011
Abstract
Te network structure of many physical systems is represented by math-
ematical entities known as graphs. Tis document examines several of the
computational algorithms of graph theory most relevant to network anal-
ysis.
Copyright 1990 - 2011 Timothy Vismor
CONTENTS CONTENTS
Contents
1 Graph Nomenclature 5
1.1 Subgraph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.2 Directed Graph . . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.3 Undirected Graph . . . . . . . . . . . . . . . . . . . . . . . . 6
1.4 Paths and Connected Graphs . . . . . . . . . . . . . . . . . . 7
1.5 Cyclic Graph . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.6 Acyclic Graph . . . . . . . . . . . . . . . . . . . . . . . . . . 7
2 Modeling Graphs 9
2.1 Representing Graphs as Lists . . . . . . . . . . . . . . . . . . . 10
2.2 Representing Graphs as Adjaceny Matrices . . . . . . . . . . . 10
2.3 Representing Sparse Graphs as Adjaceny Lists . . . . . . . . . 11
3 Abstract Data Types for Graphs 13
3.1 Adjacency List . . . . . . . . . . . . . . . . . . . . . . . . . . 13
3.2 Reduced Graph . . . . . . . . . . . . . . . . . . . . . . . . . . 14
3.3 List . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
3.4 Mapping . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
4 Creating Adjacency Lists 16
5 Depth First Search 17
5.1 Recursive Depth First Search . . . . . . . . . . . . . . . . . . 18
5.2 Non-recursive Depth First Search . . . . . . . . . . . . . . . . 19
5.3 Depth First Spanning Trees . . . . . . . . . . . . . . . . . . . 20
5.4 Depth First Traversal . . . . . . . . . . . . . . . . . . . . . . . 20
6 Graph Structure Analysis 21
6.1 Connected Components of a Graph . . . . . . . . . . . . . . . 22
6.2 Isolated Vertex Detection . . . . . . . . . . . . . . . . . . . . 22
6.3 Cycle Detection . . . . . . . . . . . . . . . . . . . . . . . . . 22
6.3.1 Detecting Cycles in Undirected Graphs . . . . . . . . 23
6.3.2 Detecting Cycles in Directed Graphs . . . . . . . . . . 24
7 Determining the Degree of Each Vertex 25
2
LIST OF FIGURES LIST OF ALGORITHMS
8 Vertex Elimination 26
8.1 Eliminating a Single Vertex . . . . . . . . . . . . . . . . . . . 26
8.2 Eliminating Many Vertices . . . . . . . . . . . . . . . . . . . . 27
8.3 Initializing Minimum Degree Vertex Tracking . . . . . . . . . 28
8.4 Maintaining the Reduced Graph . . . . . . . . . . . . . . . . 29
8.5 Querying the Reduced Graph State . . . . . . . . . . . . . . . 30
List of Figures
1 Example of a Directed Graph . . . . . . . . . . . . . . . . . . 6
2 Example of an Undirected Graph . . . . . . . . . . . . . . . . 7
3 Example of Cycles in a Digraph . . . . . . . . . . . . . . . . . 8
4 Example of an Acyclic Digraph . . . . . . . . . . . . . . . . . 8
5 Example of a Directed Tree . . . . . . . . . . . . . . . . . . . 9
6 Example of a Rooted Free Tree . . . . . . . . . . . . . . . . . 9
7 Adjacency List of Directed Graph in Figure 1 . . . . . . . . . 12
8 Adjacency List of Undirected Graph in Figure 2 . . . . . . . . 12
List of Tables
1 Vertex Degree Summary for Figure 1 . . . . . . . . . . . . . . 6
List of Algorithms
1 Create Adjacency List of Undirected Graph . . . . . . . . . . . 16
2 Map Vertices To Labeling Order . . . . . . . . . . . . . . . . . 16
3 Create Ordered Adjacency List . . . . . . . . . . . . . . . . . 17
4 Depth First Search . . . . . . . . . . . . . . . . . . . . . . . . 18
5 Recursive Depth First Search . . . . . . . . . . . . . . . . . . 18
6 Depth First Search With Recursion Removed . . . . . . . . . . 19
7 Non-recursive DFS Vertex Visitation . . . . . . . . . . . . . . 19
8 Depth First Traversal . . . . . . . . . . . . . . . . . . . . . . . 21
9 Extract the Connected Components of a Graph . . . . . . . . 22
10 Isolated Vertex Detection . . . . . . . . . . . . . . . . . . . . 23
11 Cycle Detection in Undirected Graphs . . . . . . . . . . . . . 23
12 Cycle Detection in Directed Graphs . . . . . . . . . . . . . . . 24
13 Determine Vertex Degree Using Adjacency List . . . . . . . . 25
14 Determine Vertex Degree of Directed Graph Using Edges . . . 25
15 Determine Vertex Degree of Undirected Graph Using Edges . 26
3
LIST OF ALGORITHMS LIST OF ALGORITHMS
16 Eliminate a Vertex from a Graph . . . . . . . . . . . . . . . . 27
17 Initialize Minimum Degree Vertex Tracking . . . . . . . . . . 28
18 Increase the Degree of a Vertex . . . . . . . . . . . . . . . . . 29
19 Decrease the Degree of a Vertex . . . . . . . . . . . . . . . . . 29
20 Remove a Vertex from the Reduced Graph . . . . . . . . . . . 30
21 Determine if a Vertex is in the Reduced Graph . . . . . . . . . 30
4
1 GRAPH NOMENCLATURE
1 Graph Nomenclature
Data structures and algorithms derived from graph theory form the basis for
many network analysis techniques. A brief review of the most relevant aspects
of computational graph theory follows. An excellent introduction to the sub-
ject is found in Aho, Hopcroft, and Ullman(1983) [1]. Horowitz and Sahni
(1978) [2] cover similar material in a more disjointed fashion. Even (1980) [3]
provides a more theoretical examination of the subject.
Te graph = (, ) consists of a nnite set of vertices () = {
1
,
2
, ,

}
and a nnite set of edges () = {
1
,
2
, ,

}.
Each edge corresponds to a pair of vertices. If edge corresponds to the
vertex pair (, ), then is incident upon vertices and . Te number of
vertices in () is indicated by ||. Te number of edges in () is indicated by
||.
A labeling (or ordering) of the graph is a mapping of the set

1, 2, ,
|
|

|
|
onto ().
Te usual convention for drawing a graph, is to represent each vertex as a
dot and each edge as a line connecting two dots. If the graph is directed, an
arrow is superimposed on each edge to show its orientation.
1.1 Subgraph
A graph

is a subgraph of if the following conditions apply.




().

) consists of edges (, ) in () where both and are in



(

).
If

) consists of all the edges in () for which the second condition


holds, then

is an induced subgraph of . An induced subgraph of that is


not a proper subset of any other connected subgraph of is called a connected
component of .
1.2 Directed Graph
If the edges of are ordered pairs, then is a directed graph. In a directed
graph, (, ) (, ).
A directed graph is often referred to as a digraph. If edge of a digraph
is represented by (, ), then is an edge from to . Vertex is adjacent
to vertex . Vertex is not adjacent to vertex unless the edge (, ) also
5
1.3 Undirected Graph 1 GRAPH NOMENCLATURE
2
5
1
4
3
6
Figure 1: Example of a Directed Graph
exists in . Te number of vertices adjacent to vertex is the degree of . In-
degree indicates the number of edges incident upon . Out-degree indicates the
number of edges emanating from .
Figure 1 depicts a directed graph with six vertices and ten edges. In the
ngure, the arrowheads indicate the direction of the edge.
Table 1 summarizes the degree of each vertex in Figure 1.
Table 1: Vertex Degree Summary for Figure 1
Vertex Degree In-Degree Out-Degree
1 2 1 1
2 4 1 3
3 4 2 2
4 4 3 1
5 3 2 1
6 3 1 2
1.3 Undirected Graph
If the edges of are unordered pairs, is a undirected graph. In an undirected
graph, (, ) = (, ). If edge of an undirected graph is represented by (, ),
then is adjacent to and is adjacent to . Te terminology undirected
graph is somewhat cumbersome. In this document, undirected graphs are often
referred to as just graphs.
Figure 2 depicts an undirected graph with six vertices and eight edges. Te
fact that the graph is undirected is indicated by the absence of directionality
arrows.
6
1.4 Paths and Connected Graphs 1 GRAPH NOMENCLATURE
2
5
1
4
3
6
Figure 2: Example of an Undirected Graph
1.4 Paths and Connected Graphs
A path is a sequence of edges, e.g. (
1
,
2
), (
2
,
3
), , (
1
,

). Tis path con-


nects vertices
1
and

. Te path may also be represented by the vertex se-


quence
1
,
2
,
3
, ,
1
,

. Te path begins at vertex


1
passes through ver-
tices
2
,
3
, ,
1
and ends at vertex

.
Te number of edges that comprise a path is its length. A path is simple if
all of the vertices on a path are distinct (with the possible exception of the nrst
and last vertices).
If some path connects each pair of vertices in , then is a connected graph.
Connected digraphs are classined as either weakly connected or strongly con-
nected. A strongly connected digraph has a directed path that connects all the
vertices in the graph. All the vertices of a strongly connected digraph must have
an in-degree of at least one.
A weakly connected digraph has has an undirected path that connects all the
vertices in the graph. All the vertices of a weakly connected digraph must have
either an in-degree or out-degree of at least one.
1.5 Cyclic Graph
A cycle is a simple path that begins and ends at the same vertex and has a length
of at least one. We refer to any graph that contains a cycle as a cyclic graph.
Figure 3 illustrates the cycles that are present in the directed graph of Fig-
ure 1.
1.6 Acyclic Graph
A directed graph with no cycles is called directed acyclic graph or a DAG for
short. An acyclic digraph has at least one vertex with an out-degree of zero.
7
1.6 Acyclic Graph 1 GRAPH NOMENCLATURE
2
5
1
4
3
6
Figure 3: Example of Cycles in a Digraph
2
5
1
4
3
6
Figure 4: Example of an Acyclic Digraph
Figure 4 shows a variant of the directed graph of Figure 1 that contains no
cycles. You will observe that vertex 4 has an out-degree of zero.
A directed tree is a connected DAG with the following properties:
Tere is one vertex, called the root, which no edges enter.
All vertices except the root have one entering edge.
Tere is a unique path from each vertex to the root.
A DAG consisting of one or more trees is called a forest. If the graph
= (, ) is a forest and the edge (, ) is in (), vertex is the parent of
and vertex is the child of . If there is a path from to , then vertex
is an ancestor of and vertex is a descendent of . A vertex with no proper
descendants is a leaf. A vertex and its descendants form a subtree of . Te
vertex is the root of this subtree. Te depth of vertex is the length of the
path from the root to . Te height of vertex is the length of the longest path
from to a leaf. Te height of a tree is the height of its root. Te level of vertex
is its depth subtracted from the height of the tree.
Figure 5 depicts a directed tree. Its root is vertex 1. Its leaves are the set of
vertices () = {3, 4, 6, 8, 9}.
8
2 MODELING GRAPHS
1
4
7 2 5
3 8 9 6
Figure 5: Example of a Directed Tree
1
4
7 2 5
3 8 9 6
Figure 6: Example of a Rooted Free Tree
An undirected, connected, acyclic graph is called a free tree or an undirected
tree. A rooted free tree is a free tree in which one vertex has been designated
as the root. A directed tree is converted into a rooted free tree by discarding
the orientation of the edges. A rooted free tree is converted into a directed tree
by orienting each edge away from the root. Te terminology which applies to
directed trees also applies to rooted free trees.
Figure 6 depicts the directed tree of Figure 5 converted into a rooted free
tree.
2 Modeling Graphs
A number of dierent data structures provide useful representations of a graph
. Dierent representations of often lend themselves to specinc applications.
Indeed, the eciency of graph algorithms often relies on the manner in which
a graph is represented. For this reason, it may prove necessary to transform
a graph from one representation to another to implement a complex series of
graph operations. It can be shown that converting between representations
requires no more than

||
2

operations.
9
2.1 Representing Graphs as Lists 2 MODELING GRAPHS
2.1 Representing Graphs as Lists
Te most obvious data structure for representing a graph arises directly from its
dennition. is described by two simple lists:
A vertex list (), and
An edge list () which represents each edge as a pair of vertices.
Tis data structure often forms the basis of the interface between the user
and graph algorithms. Te reasons are twofold:
For many people, it is the most natural way to describe the connections
in a graph.
It is a relatively ecient way to represent sparse graphs.
As an example, consider the directed graph of Figure 1. It has six vertices.
Its vertex list is simply
()

= {1, 2, 3, 4, 5, 6}
Te directed graph in Figure 1 has ten edges. Its edge list follows.
()

= {(1, 3), (2, 1)(2, 3), (2, 4), (3, 2), (3, 5), (4, 6), (5, 4), (6, 4), (6, 5)}
Te corresponding undirected graph shown in Figure 2 has the same six vertices.
()

= {1, 2, 3, 4, 5, 6}
However, it has 16 edges.
()

= {(1, 2), (1, 3), (2, 1)(2, 3), (2, 4), (3, 1), (3, 2), (3, 5),
(4, 2), (4, 5), (4, 6), (5, 3), (5, 4), (5, 6), (6, 4), (6, 5)}
2.2 Representing Graphs as Adjaceny Matrices
An alternate representation of is known as an adjacency matrix. In this data
structure, a || || matrix is established such that

=

1 when vertex is adjacent to vertex
0 when vertex is not adjacent to vertex
(1)
10
2.3 Representing Sparse Graphs as Adjaceny Lists 2 MODELING GRAPHS
Te storage required to implement an adjacency matrix is proportional to ||
2
.
When is represented as an adjacency matrix, the best time complexity you
can expect for graph algorithms is

||
2

. Tis is the time required to access


each element of the matrix exactly one time.
Once again consider the directed graph of Figure 1. Its adjacency matrix
follows.

0 0 1 0 0 0
1 0 1 1 0 0
0 1 0 0 1 0
0 0 0 0 0 1
0 0 0 1 0 0
0 0 0 1 1 0

Te adjacency matrix of the undirected version of the graph (Figure 2) is as


follows.

0 1 1 0 0 0
1 0 1 1 0 0
1 1 0 0 1 0
0 1 0 0 1 1
0 0 1 1 0 1
0 0 0 1 1 0

Observe that the adjacency matrix of an undirected graph is symmetric.


2.3 Representing Sparse Graphs as Adjaceny Lists
An adjacency list is a data structure for representing adjacency relationships in
sparse graphs. Te adjacency list of is actually a set of || linked lists. Each
vertex is the head of a list. Vertices adjacent to form the body of each list. If
a vertex is not adjacent to any other vertices its list is empty.
Te storage required to implement an adjacency list is proportional to || +
||. When is represented as an adjacency list, the best time complexity you
can expect for graph algorithms is (|| + ||). Te time required to access each
vertex and each edge exactly one time. An algorithm whose time complexity is
(|| + ||) is sometimes referred to as linear in the size of .
Figure 7 depicts the adjacency list for the directed graph in Figure 1.
Figure 8 depicts the adjacency list for the undirected graph in Figure 2.
11
2.3 Representing Sparse Graphs as Adjaceny Lists 2 MODELING GRAPHS
1
2
3
4
3 eol
1
2
6 eol
Vertex
5
6
4 eol
4
3 4 eol
5 eol
5 eol
Adjacent Vertices
Figure 7: Adjacency List of Directed Graph in Figure 1
1
2
3
4
2
1
2
2
Vertex
5
6
3
4
3 4 eol
5 eol
5 eol
Adjacent Vertices
3 eol
5 6 eol
4 6 eol
Figure 8: Adjacency List of Undirected Graph in Figure 2
12
3 ABSTRACT DATA TYPES FOR GRAPHS
3 Abstract Data Types for Graphs
Graph algorithms in this document are described using an abstract data type
paradigm. Tat is, data sets and operators are specined, but the actual data
structures used to implement them remain undenned. Any data structure that
eciently satisnes the constraints imposed in this section is suited for the job.
All signals emitted by operators denned in this section are used to navigate
through data, not to indicate errors. Error processing is intentionally omitted
from the algorithms in this document. Te intent is to avoid clutter that ob-
scures the nature of the algorithms.
3.1 Adjacency List
An adjacency list, , is a data type for representing adjacency relationships of
the sparse graph = (, ). Adjacency lists are described in detail in Section
2.3 of this document.
An adjacency list is typically stored in a dynamic data structure that iden-
tines the edge from vertex to vertex as an ordered pair of vertex labels (, ).
Descriptive information is usually associated with each edge.
More specincally, the following operations are supported on an adjacency
list :
Insert adds an arbitrary edge (, ) to . If edge (, ) is not already in
the list, insert signals a successful insertion.
Get retrieves an arbitrary edge (, ) from . When edge (, ) is in , get
signals a successful lookup.
Scan permits sequential access to all edges incident upon vertex . Vertex
scans are bounded. More specincally, a vertex scan nnds all edges (, )
such that

. When scan nnds edge (, ), it returns .


When a vertex scan has exhausted all entries in its range, a nished signal
is emitted.
A scan has two support operations: push and pop. A push suspends
the scan at its current position. A pop resumes a suspended scan. Te
push and pop operations permit scans to be nested.
Put updates the information associated with an arbitrary edge (, ) in .
Te algorithms assume that read operations (get and scan) make edge
information available in a buer (this buer is usually denoted by the symbol
13
3.2 Reduced Graph 3 ABSTRACT DATA TYPES FOR GRAPHS
). Update operations (insert and put) modify the description of an edge
based on the current contents of the communication buer.
Algorithms for creating adjacency lists are examined in Section 4.
3.2 Reduced Graph
A reduced graph,

= (

,

), is a data structure that supports the systematic


elimination of all vertices from the graph = (, ). Te vertices of the re-
duced graph are denoted as

(

) and its edges as

). A crucial attribute
of the reduced graph is ecient identincation of the vertex in

(

) with the
minimum degree.
A reduced graph supports the following operations:
Increase_degree increases the degree of vertex in

(

) by one.
Decrease_degree decreases the degree of vertex in

(

) by one.
Remove excises vertex from $

(

) .
In_graph tests to see whether vertex is in

(

).
Minimum_degree nnds the vertex in

(

) with the smallest degree.


Te topic of vertex elimination and ecient techniques for facilitating the
elimination of many vertices are examined in detail in Section 8 of this docu-
ment.
3.3 List
A simple list is an ordered set of elements. If the set {
1
, ,

,
+1
, ,

}
represents , then the list contains elements. Element
1
is the nrst item on
the list and

is the last item on the list. Element

precedes
+1
and element

+1
follows

. Element

is at position in . Descriptive information may


accompany each item on a list. Lists associated with graph algorithms support
the following operations:
Link adds an element to a list at position . Inserting element position
results in an updated list: {
1
, ,
1
, ,

,
+1
, ,

} An insertion at
position appends to the end of the list.
Unlink removes the element at position fromthe list. Deleting element
results in the list {
1
, ,
1
,
+1
, ,

}.
14
3.4 Mapping 3 ABSTRACT DATA TYPES FOR GRAPHS
Find looks for an element on the list and returns its position. If the
element is not a member of the list, is returned.
First returns the position of the nrst item on the list. When the list is
empty, is returned.
Next returns position + 1 on the list if position is provided. When

is the last item on the list, is returned.


Previous returns position 1 on the list if position is provided. If
is one, is returned.
A linked list refers to a list implementation that does not require its mem-
bers to reside in contiguous storage locations. In this environment, an ecient
implementation of the previous operator dictates the use of a doubly linked
list.
Communicating with a simple list is analogous to adjacency list communi-
cation. Read operations (nd, rst, next, and previous) make list infor-
mation available in a buer. Update operations (link, unlink) modify the
list based on the current contents of the buer.
If it is necessary to distinguish discrete elements in the communication buer,
the structure notation of the C programming language is used. For example,
consider a set of edges maintained in a list whose communication buer is
. Each edge in is denned by the pair of vertices (, ) that constitute its
endpoints. In this situation, the endpoints of edge are referenced as . and
..
3.4 Mapping
Amapping relates elements of its domain to elements of its range as follows.
() =
A mapping resides in a data structure that supports two operations:
Map links an element in the range of to an arbitrary element in the
domain of , i.e. sets () to .
Evaluate evaluates the mapping for an arbitrary element in its do-
main, i.e. returns ().
15
4 CREATING ADJACENCY LISTS
Algorithm 1: Create Adjacency List of Undirected Graph
=first ( )
whi l e
insert ( , , )
=next ( , )
=first ( )
whi l e
insert ( , ., .)
insert ( , ., . )
=next ( , )
Algorithm 2: Map Vertices To Labeling Order
= 0
=first ( )
whi l e
= + 1
map ( , , )
=next ( , )
4 Creating Adjacency Lists
An undirected graph = (, ) is represented by the sets () and (). If
these sets are maintained as simple lists where the buer communicates with
the vertex list and communicates with the edge list, Algorithm 1 creates an
adjacency list for .
Te nrst loop in Algorithm1 creates a header for each vertex. Tis operation
is not strictly necessary given the current data dennition; however, it is often
required in practical implementations.
You should observe that the algorithm inserts each edge in () into the ad-
jacency list twice: once in the stated direction and once in the reverse direction.
If is a directed graph, the reverse insertion is inappropriate (i.e. omit the nnal
insert statement in Algorithm 1). It should be apparent that the algorithm has
a time complexity of (|| + ||) if all operators have time complexity of (1).
It is often benencial to create an adjacency list based on an alternate labeling
of the vertices of . Tis operation requires a mapping of the integers from
1 to || onto the set (). Algorithm 2 maps () to the order in which it is
enumerated.
16
5 DEPTH FIRST SEARCH
Algorithm 3: Create Ordered Adjacency List
= 0
=first ( )
whi l e
= + 1
map ( , , )
insert ( , , )
=next ( , )
= first ( )
whi l e
=evaluate ( , . )
=evaluate ( , .)
insert ( , , )
insert ( , , )
=next ( , )
Algorithm 3 combines these two procedures. It labels () according to its
order of enumeration and creates an adjacency list based on this labeling.
If map and evaluate have constant time complexity, the overall algorithm
retains its linear complexity.
Note. In a practical implementation, map will insert the pair (, ) into
a data structure that is optimized for searching and evaluate will look up
in this data structure. Ecient operations of this sort have a time com-
plexity of

log
2

. Terefore, adjacency list creation will have complexity

|| log
2
|| + || log
2
||

.
5 Depth First Search
Given a graph = (, ) and a vertex (), a depth-nrst search nnds all
the vertices () for which there is a path from to . In other words, a
depth-nrst search nnds the connected component of that contains . It does
so by starting at and systematically searching until no more vertices can be
reached. After a vertex is reached by the search, it is referred to as visited. A
vertex is explored after all adjacent vertices are visited. Te vertex that anchors
the search is referred to as its root.
When a depth-nrst search reaches vertex , it immediately suspends its ex-
ploration of and explores any unvisited vertex adjacent to . Te exploration
of resumes only after the exploration of has nnished. Te order in which
17
5.1 Recursive Depth First Search 5 DEPTH FIRST SEARCH
Algorithm 4: Depth First Search
whi l e next ( )
map ( , , )
= = 0
dfs ( )
Algorithm 5: Recursive Depth First Search
dfs( )
= + 1
map ( , , )
map ( , , )
= + 1
f o r all vertices adjacent to
i f evaluate ( , ) is
map ( , , )
dfs ( )
= 1
a depth-nrst search visits a graph is a generalization of the order in which a
preorder traversal visits the vertices of a tree. If is a tree, a depth-nrst search
produces a preorder traversal of .
5.1 Recursive Depth First Search
Algorithm 4 performs a depth-nrst search of rooted at . Te counters
and are global. It relies upon the recursive procedure dfs. Algorithm 5
sketches the implementation of the dfs procedure.
Observe that Algorithm 5 produces three mappings as it performs the DFS:
the depth nrst ordering , the vertex depth map , and the predecessor map
. Tese mappings provide useful information concerning the structure of the
graph. However, only is actually required by the algorithm. It is initialized
with all vertices marked as and updated as each node is visited.
Te time complexity of a depth-nrst search is linear in the size of , i.e.
(|| + ||). To achieve this linear time complexity, the implementation of the
adjacency list is crucial. More specincally, some indication of the most recently
visited neighbor (call it vertex ) must be maintained for each active vertex
. Tis permits the scan of s adjacency list to resume at the point where it
18
5.2 Non-recursive Depth First Search 5 DEPTH FIRST SEARCH
Algorithm 6: Depth First Search With Recursion Removed
dfs( )
visit ( , )
=
next edge
f o r all vertices adjacent to
i f evaluate ( , ) is
= + 1
visit ( , )
=
goto next edge
i f
=evaluate ( , )
= 1
goto next edge
Algorithm 7: Non-recursive DFS Vertex Visitation
visit( , )
map ( , , )
map ( , , )
= + 1
map ( , , )
was suspended when the exploration of is nnished. If you have to rescan the
adjacency list of to pick up where you left o, linearity is lost.
5.2 Non-recursive Depth First Search
Since the procedure described in Section 5.1 has a depth of recursion of || in the
worst case, Algorithm 5 may have unacceptable execution characteristics (such
as stack overnow) for large graphs. Algorithm 6 removes the recursion from the
dfs function.
Te vertex visitation procedure visit is straightforward and is specined in
Algorithm 7.
Observe that vertex visitation (Algorithm 7) generates the three mappings
(, , and ) that were produced by the recursive procedure. Note that the pre-
decessor mapping is required by the unwound dfs procedure. It was not
19
5.3 Depth First Spanning Trees 5 DEPTH FIRST SEARCH
required by the recursive implementation since equivalent information is im-
plicitly retained on the stack during recursion.
Te computational complexity of this unwound procedure is similar to that
of the recursive implementation.
When implementing non-recursive depth nrst search, dont forget that the
dfs function of Algorithm 6 is imbedded in the overall procedure denned by
Algorithm 4.
See Section 5.1 for more information on these issues.
5.3 Depth First Spanning Trees
Any edge (, ) that leads to the discovery of an unvisited vertex during a depth-
nrst search is referred to as a tree edge of . Collectively, the tree edges of
form a depth-nrst spanning tree of . Tree edges are detected as follows:
In Algorithm 5, the recursive depth-nrst search of Section 5.1, only the
tree edges will cause map(, , ) to execute.
In Algorithm 6, the non-recursive depth-nrst search of Section 5.2, only
tree edges cause visit(, ) to execute.
If is a directed graph, an edge that connects a vertex to one of its ancestors
in the spanning tree is referred to as a back edge. An edge that connects a vertex
to one of its descendants in the spanning tree is referred to as a forward edge. If
is neither an ancestor nor descendant of , then (, ) is called a cross edge.
If is an undirected graph, the depth-nrst spanning tree simplines as fol-
lows:
Back edges and forward edges are not distinguished.
Cross edges do not exist.
Terefore, only two types of edge are denned for undirected graphs. We will
call them tree edges and back edges.
5.4 Depth First Traversal
Following the lead of Horowitz and Sahni (1978) [2], a distinction is made
between a depth-nrst search (Sections 5.1 and 5.2) and a depth-nrst traversal.
Given a graph = (, ), a series of depth-nrst searches that visit all the vertices
in () is referred to as a depth-nrst traversal. If is a connected graph, a
20
6 GRAPH STRUCTURE ANALYSIS
Algorithm 8: Depth First Traversal
=first ( )
whi l e
map ( , , )
=next ( , )
= 0
=first ( )
whi l e
i f evaluate ( , ) is
= 0
dfs ( )
=next ( , )
single depth-nrst search produces a depth-nrst traversal. Otherwise, a depth-
nrst traversal will discover all of the connected components of .
Algorithm 8 determines a depth-nrst traversal of . It assumes the buer
is used to communicate with the vertex list.
Te time complexity of a depth-nrst traversal is linear if dfs is linear.
6 Graph Structure Analysis
A depth-nrst search can be used to preprocess a graph or it can be directly em-
bedded in a more complex algorithm. In the latter case, the action taken when
a vertex is visited depends on the algorithm in which the search is embedded.
In the former case, the normal objective of the search is to gather information
about the structure of the graph (as seen from the vantage point of the search).
Recall that Algorithms 5 and 6 gathered three bits of structural information
as it proceeded:
Te depth-nrst labeling () is the order in which was visited during the
search. Depth-nrst numbers range from 1 to ||. Te root is mapped to
one.
Te predecessor (or parent) mapping () identines the vertex fromwhich
was discovered during the search. Te root has no parent.
Te depth mapping () is the length of the path from to its root in the
depth-nrst spanning tree of .
21
6.1 Connected Components of a Graph 6 GRAPH STRUCTURE ANALYSIS
Algorithm 9: Extract the Connected Components of a Graph
=first ( )
whi l e
map ( , , )
=next ( , )
= 0
=first ( )
whi l e
i f evaluate ( , ) is
= 0
dfs ( )
=next ( , )
Subsequent sections provide algorithmic examples of structural information
about a graph that is obtained by making small alterations to the depth-nrst
search and depth-nrst traversal algorithms.
6.1 Connected Components of a Graph
If () (), a similar procedure (Algorithm 9) extracts a set of components
from whose roots are denned by (). It assumes that () and () are
maintained in simple lists (Section 3.3 examines the list data type).
6.2 Isolated Vertex Detection
Isolated vertices are detected during a depth-nrst traversal of a graph. Te detec-
tion scheme is based on the observation that an isolated vertex processed by dfs
increases the depth-nrst number by exactly one. Algorithm 10 implements this
observation in the main loop of a depth-nrst traversal (Algorithm 8). It assumes
the buer provides communication with the vertex list.
Since the isolated vertex test is an O(1) operation, it does not increase the
complexity of a depth-nrst traversal.
6.3 Cycle Detection
It can be shown that each back edge detected during a depth-nrst search of the
graph = (, ) corresponds to a cycle in . Recall from Section 5.3 that a
back edge connects a vertex to one of its ancestors in the spanning tree.
22
6.3 Cycle Detection 6 GRAPH STRUCTURE ANALYSIS
Algorithm 10: Isolated Vertex Detection
= 0
=first ( )
whi l e
i f evaluate ( , ) is
= 0
=
dfs ( )
i f i s + 1
isoiario viirix
=next ( , )
Algorithm 11: Cycle Detection in Undirected Graphs
next edge
f o r all vertices adjacent to
i f evaluate ( , ) is
= + 1
visit ( , )
=
e l s e
c\cii oiricrio
goto next edge
A minor modincation of the depth-nrst search will produce a test for cycles.
We will examine the case of cycle detection in undirected graphs nrst. It is
simpler.
6.3.1 Detecting Cycles in Undirected Graphs
Algorithm 11 implements a cycle test for undirected graphs that is illustrated
on a fragment of Algorithm 6, the non-recursive dfs procedure.
Since the cycle test is an (1) operation, it does not increase the complexity
of the depth-nrst search.
23
6.3 Cycle Detection 6 GRAPH STRUCTURE ANALYSIS
Algorithm 12: Cycle Detection in Directed Graphs
next edge
f o r all vertices adjacent to
i f evaluate ( , ) is
= + 1
visit ( , )
=
e l s e
i f evaluate ( , ) >evaluate ( , ) and
evaluate ( , ) <evaluate ( , )
c\cii oiricrio
goto next edge
6.3.2 Detecting Cycles in Directed Graphs
Testing for cycles in directed graphs is still a matter of looking for back edges.
However, the process is complicated by the fact that the edges of a digraph that
are not part of its spanning forest are not necessarily back edges either. Te
following observations permit the forward edges, cross edges, and back edges of
a depth-nrst search to be distinguished eciently.
It can be shown that the forward edges of a depth-nrst search connect ver-
tices with low depth-nrst numbers to vertices with high depth-nrst numbers.
Terefore, an edge (, ) of that is not part of its spanning forest is a forward
edge when () < ().
Conversely, (, ) is a back edge or cross edge of when () > ().
Distinguishing between back edges and cross edges relies on the observation
that a cross edge connects the current spanning tree to a spanning tree that was
explored at an earlier stage of a depth-nrst traversal. Since the root of the
current spanning tree must have a larger depth-nrst number than any vertex in
any previously processed tree in the spanning forest, the condition () > ()
must hold for a cross edge (, ).
Terefore, an edge (, ) of that is not part of its spanning forest is a back
edge when the following conditions apply: () > () and () < ().
Tis observation leads to Algorithm 12 for detecting cycles in a directed
graph, it is a modincation to Algorithm 6, the non-recursive depth-nrst search.
Obviously, the cycle test does not increase the complexity of the algorithm.
24
7 DETERMINING THE DEGREE OF EACH VERTEX
Algorithm 13: Determine Vertex Degree Using Adjacency List
=first ( )
whi l e
map ( , , 0 )
=next ( , )
=first ( )
whi l e
f o r all vertices adjacent to
=evaluate ( , ) +1
map ( , , )
=next ( , )
Algorithm 14: Determine Vertex Degree of Directed Graph Using Edges
=first ( )
whi l e
map ( , , 0 )
=next ( , )
=first ( )
whi l e
=evaluate ( , . ) +1
map ( , ., )
=next ( , )
7 Determining the Degree of Each Vertex
If the graph = (, ) is represented by its adjacency list () and vertex list
(), Algorithm 13 develops a mapping whose domain is () and whose
range is the degree of (). It assumes the buer provides communication
with the vertex list.
If is a directed graph, represented by its vertex list () and edge list (),
Algorithm 14 maps each vertex in () to its degree. It is assumed that each
edge is represented by an ordered pair of vertices (, ) and the buer provides
communication with the edge list.
If is an undirected graph, Algorithm 15 performs the same operation. It
is assumed that each edge is represented by an unordered pair of vertices (, ).
If all the elementary operations are (1), creating is linear, i.e. has com-
plexity (|| + ||).
25
8 VERTEX ELIMINATION
Algorithm 15: Determine Vertex Degree of Undirected Graph Using Edges
=first ( )
whi l e
map ( , , 0 )
=next ( , )
=first ( )
whi l e
=evaluate ( , . ) +1
map ( , ., )
=evaluate ( , .) +1
map ( , ., )
=next ( , )
8 Vertex Elimination
Eliminating a vertex from the graph = (, ) creates a reduced graph

=
(

,

) with the following characteristics:


Te set of vertices

is the subset of () that does not contain .
Te set of edges

does not contain any edges that were incident upon .


Te set of edges

contains edges that connect all vertices in () that


were adjacent to .
In other words, you get

from by
1. Removing vertex from ().
2. Removing all edges that were incident upon from ().
3. Adding edges to () that connect all the vertices that were adjacent to
.
8.1 Eliminating a Single Vertex
Assuming that the graph is represented by a list of vertices () and a list of
edges (), Algorithm 16 eliminates vertex from . It assumes the buer
provides communication with the edge list.
Te operation adjacency_list creates an adjacency list from () and
(). In Section 4, Algorithms 1 and Algorithm 3 were presented to solve this
26
8.2 Eliminating Many Vertices 8 VERTEX ELIMINATION
Algorithm 16: Eliminate a Vertex from a Graph
adjacency_list( , )
f o r all vertices adjacent to
f o r all vertices adjacent to
i f and find ( , , ) is
. =
. =
link ( , 1 )
=find ( , , )
unlink ( , )
=find ( , )
unlink ( , )
problem. New edges created during vertex elimination are arbitrarily inserted
at the beginning of the edge list. For the current purposes, the insertion point
is irrelevant.
8.2 Eliminating Many Vertices
Te vertex elimination procedure outlined in Algorithm 16 of Section 8.1 is
primarily illustrative. When multiple vertices are eliminated, it is usually quite
inecient to create an adjacency list each time you want to eliminate a vertex
from a graph.
Many of the algorithms discussed in the companion document Matrix Algo-
rithms
1
require an ecient vertex elimination model that supports the sequen-
tial elimination of all vertices () from the graph = (, ). Te procedures
are often constrained such that each stage of the process eliminates the min-
imum degree vertex from the reduced vertex set

(

). Additionally, the
vertex elimination procedures are often prohibited the modifying of the adja-
cency list of the graphs (). Recall from Section 3.2 that vertex elimination
data structures must also support the following operations:
Increase_degree increases the degree of vertex by one.
Decrease_degree decreases the degree of vertex by one.
Remove excises vertex from $

(

) .
1
https://vismor.com/documents/network_analysis/matrix_algorithms/
27
8.3 Initializing Minimum Degree Vertex Tracking 8 VERTEX ELIMINATION
Algorithm 17: Initialize Minimum Degree Vertex Tracking
compute_degree ( , , )
=first ( )
whi l e
=
link ( , )
=next ( , )
merge_sort ( , )
In_graph determines whether vertex is in

(

).
Minimum_degree nnds the vertex in

(

) with the smallest degree.


Subsequent sections of this document examine the implementation of these
operations.
8.3 Initializing Minimum Degree Vertex Tracking
Te following data structure is proposed to support ecient tracking the mini-
mum degree vertex during sequential vertex elimination:
A mapping between each vertex in () and its degree.
A list which orders

(

) by ascending degree.
Algorithm 17 initializes this data structure for the graph based on its adja-
cency list () and vertex list (). Observe that, per the comments in Section
8.2, () is unchanged by this operation.
Te procedure compute_degree creates the vertex degree mapping based
on () and (). Algorithm 13 is a candidate for compute_degree.
Te procedure merge_sort sorts the list based on the mapping . Its
name suggests that a merge sort may be the appropriate sorting algorithm. Te
minimum number of comparisons required to sort a set of keys is ln . Te
merge sort algorithm is ( ln ) in both its best and worst case and is partic-
ularly suited for use with linked lists. Furthermore, merge sort does not suer
from the potentially catastrophic worst case stack growth that is common in re-
cursive sorting algorithms. Te depth of recursion of a merge sort is bounded by
log . Tis implies that sorting 1,000,000 items would require no more than
20 nested function calls. An ecient implementation of merge sort needs at
most 4 to 8 bytes of local stack space for each level of recursion.
28
8.4 Maintaining the Reduced Graph 8 VERTEX ELIMINATION
Algorithm 18: Increase the Degree of a Vertex
increase_degree ( )
=evaluate ( , ) +1
map ( , , )
= =find ( , )
whi l e and >evaluate ( , )
= e x t ( , )
link ( , , )
unlink ( , )
Algorithm 19: Decrease the Degree of a Vertex
decrease_degree ( )
=evaluate ( , ) 1
map ( , , )
= =find ( , )
whi l e and <evaluate ( , )
=previous ( , )
link ( , , )
unlink ( , )
8.4 Maintaining the Reduced Graph
With the vertex elimination data structure established, maintenance and query
operations are straightforward. Algorithm18 implements increase_degree.
It assumes the list communication buer is .
In words, Algorithm 18 increases the degree of and scans the degree list
in ascending order until the new position of is located. It then adds into at
this position and deletes from the old position. In the worst case, the loop in
Algorithm 18 is an

|

|

operation. Tis degenerate case only occurs when


all vertices in

(

) have the same degree and is the nrst item in .


Algorithm 19 implements the decrease_degree operation. It decreases
the degree of then scans the degree list in descending order until the new
position of is located. It then adds into at this position and deletes from
the old position. Once again, Algorithm 19 is an

|

|

in the worse case. In


the average case, it is much closer (1).
Te remove operator (Algorithm 20) excises from the degree list and
makes sure its degree count is less than or equal to zero in the mapping .
29
8.5 Querying the Reduced Graph State REFERENCES
Algorithm 20: Remove a Vertex from the Reduced Graph
remove ( )
=find ( , )
unlink ( , )
map ( , , 0 )
Algorithm 21: Determine if a Vertex is in the Reduced Graph
in_graph ( )
i f evaluate ( , ) > 0
is ix ciaiu
e l s e
is xor ix ciaiu
8.5 Querying the Reduced Graph State
A couple of reduced graph state operations are also specined in Section 8.1.
Teir implementations tend to fall out trivially from the data structures used
for minimum degree vertex tracking.
Te in_graph operator is realized by the mapping . If the degree of ver-
tex is greater than zero, then is in

(

). Algorithm 21 formalizes this


observation.
In a similar vein, the minimum_degree operation is realized by the list op-
eration rst. By dennition, rst() gets the minimum degree vertex. Recall
that the minimum degree vertex list orders the vertices by ascending degree.
References
[1] A. Aho, J. Hopcroft, and J. Ullman, e Design and Analysis of Computer
Algorithms, Addison-Wesley, Reading, Massachusetts, 1983. 5
[2] E. Horowitz and S. Sahni, Fundamentals of Computer Algorithms, Computer
Science Press, Rockville, Maryland, 1978. 5, 20
[3] S. Even, Graph Algorithms, Computer Science Press, Rockville, Maryland,
1980. 5
30

You might also like