Chapter 6 Graphs - PowerPoint PPT Presentation

1 / 82
About This Presentation
Title:

Chapter 6 Graphs

Description:

... bears only one sign, you will make two more, so that now the aperture bears three. ... DFS on a graph with n vertices and m edges takes O(n m ) time ... – PowerPoint PPT presentation

Number of Views:152
Avg rating:3.0/5.0
Slides: 83
Provided by: HarryPl6
Category:
Tags: bears | chapter | graphs | to

less

Transcript and Presenter's Notes

Title: Chapter 6 Graphs


1
Chapter 6Graphs
2
Outline and Reading
  • Graphs (6.1)
  • Definition
  • Applications
  • Terminology
  • Properties
  • ADT
  • Data structures for graphs (6.2)
  • Edge list structure
  • Adjacency list structure
  • Adjacency matrix structure

3
  • To find the way out of a labyrinth there is only
    one means. At every new junction, never seen
    before, the path we have taken will be marked
    with three signs. If you see that the junction
    has already been visited, you will make only one
    mark on the path you have taken. If all the
    apertures have already been marked, then you must
    retrace your steps. But if one or two apertures
    of the junction are still without signs, you will
    choose any one, making two signs on it.
    Proceeding through an aperture that bears only
    one sign, you will make two more, so that now the
    aperture bears three. All the parts of the
    labyrinth must have been visited if, arriving at
    a junction, you never take a passage with three
    signs, unless none of the other passages is now
    without signs.
  • --Ancient Arabic text

4
Graph Traversals
  • How do you find your way out of a maze, given a
    large supply of pennies?
  • Graph traversals
  • Depth-first search
  • Breadth-first search
  • Other applications Boggle, tic-tac-toe, path
    finding, theorem proving, motion planning, AI,

5
Graph
  • A graph is a pair (V, E), where
  • V is a set of nodes, called vertices
  • E is a collection of pairs of vertices, called
    edges
  • Vertices and edges are positions and store
    elements
  • Example
  • A vertex represents an airport and stores the
    three-letter airport code
  • An edge represents a flight route between two
    airports and stores the mileage of the route

6
Edge Types
  • Directed edge
  • ordered pair of vertices (u,v)
  • first vertex u is the origin
  • second vertex v is the destination
  • e.g., a flight
  • Undirected edge
  • unordered pair of vertices (u,v)
  • e.g., a flight route
  • Directed graph
  • all the edges are directed
  • e.g., route network
  • Undirected graph
  • all the edges are undirected
  • e.g., flight network

flight AA 1206
ORD
PVD
849 miles
ORD
PVD
7
Applications
  • Electronic circuits
  • Printed circuit board
  • Integrated circuit
  • Transportation networks
  • Highway network
  • Flight network
  • Computer networks
  • Local area network
  • Internet
  • Web
  • Databases
  • Entity-relationship diagram

8
Terminology
  • End vertices (or endpoints) of an edge
  • U and V are the endpoints of a
  • Edges incident on a vertex
  • a, d, and b are incident on V
  • Adjacent vertices
  • U and V are adjacent
  • Degree of a vertex
  • X has degree 5
  • Parallel edges
  • h and i are parallel edges
  • Self-loop
  • j is a self-loop

9
Terminology (cont.)
  • Path
  • sequence of alternating vertices and edges
  • begins with a vertex
  • ends with a vertex
  • each edge is preceded and followed by its
    endpoints
  • Simple path
  • path such that all its vertices and edges are
    distinct
  • Examples
  • P1(V,b,X,h,Z) is a simple path
  • P2(U,c,W,e,X,g,Y,f,W,d,V) is a path that is not
    simple

V
a
b
P1
d
X
U
Z
h
P2
c
e
W
g
f
Y
10
Terminology (cont.)
  • Cycle
  • circular sequence of alternating vertices and
    edges
  • each edge is preceded and followed by its
    endpoints
  • Simple cycle
  • cycle such that all its vertices and edges are
    distinct
  • Examples
  • C1(V,b,X,g,Y,f,W,c,U,a,?) is a simple cycle
  • C2(U,c,W,e,X,g,Y,f,W,d,V,a,?) is a cycle that is
    not simple

V
a
b
d
X
U
Z
h
C2
e
C1
c
W
g
f
Y
11
Properties
  • Notation
  • n number of vertices
  • m number of edges
  • deg(v) degree of vertex v
  • Property 1
  • Sv deg(v) 2m
  • Proof each edge is counted twice
  • Property 2
  • In an undirected graph with no self-loops and no
    multiple edges
  • m ? n (n - 1)/2
  • Proof each vertex has degree at most (n - 1)
  • What is the bound for a directed graph?
  • Example
  • n 4
  • m 6
  • deg(v) 3

12
Representing a Graph
  • Two different drawings of the same graph are
    shown.
  • What data structure to represent this graph?

13
Adjacency Matrix
  • A B C D E F G H I J K L M
  • A 1 1 0 0 1 1 0 0 0 0 0 0
  • B 0 0 0 0 0 0 0 0 0 0 0
  • C 0 0 0 0 0 0 0 0 0 0
  • D 1 1 0 0 0 0 0 0 0
  • E 1 1 0 0 0 0 0 0
  • F 0 0 0 0 0 0 0
  • G 0 0 0 0 0 0
  • H 1 0 0 0 0
  • I 0 0 0 0
  • J 1 1 1
  • K 0 0
  • L 1
  • M

Space required for a graph with v vertices, e
edges? Q(v2) Time to tell if there is an edge
from v1 to v2? Q(1)
14
Adjacency List
  • A F -gt B -gt C -gt G
  • B A
  • C A
  • D E -gt F
  • E D -gt F -gt G
  • F D -gt E
  • G A -gt E
  • H I
  • I H
  • J K -gt L -gt M
  • K J
  • L M -gt J
  • M J -gt L

Space required for a graph with v vertices, e
edges? Q(ve) Time to tell if there is an
edge from v1 to v2? Q(v)
15
Main Methods of the Graph ADT
  • Vertices and edges
  • are positions
  • store elements
  • Accessor methods
  • aVertex()
  • incidentEdges(v)
  • endVertices(e)
  • isDirected(e)
  • origin(e)
  • destination(e)
  • opposite(v, e)
  • areAdjacent(v, w)
  • Update methods
  • insertVertex(o)
  • insertEdge(v, w, o)
  • insertDirectedEdge(v, w, o)
  • removeVertex(v)
  • removeEdge(e)
  • Generic methods
  • numVertices()
  • numEdges()
  • vertices()
  • edges()

16
Asymptotic Performance
17
Depth-First Search
18
Outline and Reading
  • Definitions (6.1)
  • Subgraph
  • Connectivity
  • Spanning trees and forests
  • Depth-first search (6.3.1)
  • Algorithm
  • Example
  • Properties
  • Analysis
  • Applications of DFS (6.5)
  • Path finding
  • Cycle finding

19
Subgraphs
  • A subgraph S of a graph G is a graph such that
  • The vertices of S are a subset of the vertices of
    G
  • The edges of S are a subset of the edges of G
  • A spanning subgraph of G is a subgraph that
    contains all the vertices of G

20
Connectivity
  • A graph is connected if there is a path between
    every pair of vertices
  • A connected component of a graph G is a maximal
    connected subgraph of G

Connected graph
Non connected graph with two connected components
21
Trees and Forests
  • A (free) tree is an undirected graph T such that
  • T is connected
  • T has no cycles
  • This definition of tree is different from the one
    of a rooted tree
  • A forest is an undirected graph without cycles
  • The connected components of a forest are trees

Tree
Forest
22
Spanning Trees and Forests
  • A spanning tree of a connected graph is a
    spanning subgraph that is a tree
  • A spanning tree is not unique unless the graph is
    a tree
  • Spanning trees have applications to the design of
    communication networks
  • A spanning forest of a graph is a spanning
    subgraph that is a forest

Graph
Spanning tree
23
Depth-first Search
  • Main idea keep traveling to a
  • new, unvisited node until you you get stuck.
  • Then backtrack as far as necessary and try a new
    path.

24
Depth-First Search
  • Depth-first search (DFS) is a general technique
    for traversing a graph
  • A DFS traversal of a graph G
  • Visits all the vertices and edges of G
  • Determines whether G is connected
  • Computes the connected components of G
  • Computes a spanning forest of G
  • DFS on a graph with n vertices and m edges takes
    O(n m ) time
  • DFS can be further extended to solve other graph
    problems
  • Find and report a path between two given vertices
  • Find a cycle in the graph
  • Depth-first search is to graphs what Euler tour
    is to binary trees

25
DFS Algorithm
  • The algorithm uses a mechanism for setting and
    getting labels of vertices and edges

Algorithm DFS(G, v) Input graph G and a start
vertex v of G Output labeling of the edges of G
in the connected component of v as
discovery edges and back edges setLabel(v,
VISITED) for all e ? G.incidentEdges(v) if
getLabel(e) UNEXPLORED w ? opposite(v,e) if
getLabel(w) UNEXPLORED setLabel(e,
DISCOVERY) DFS(G, w) else setLabel(e,
BACK)
Algorithm DFS(G) Input graph G Output labeling
of the edges of G as discovery edges
and back edges for all u ? G.vertices() setLab
el(u, UNEXPLORED) for all e ? G.edges() setLabel
(e, UNEXPLORED) for all v ? G.vertices() if
getLabel(v) UNEXPLORED DFS(G, v)
26
Non-recursive DFS
  • How can you implement DFS non-recursively?
  • Use a stack
  • For unconnected graphs, restart at unvisited
    nodes
  • Runtime?
  • O(nm)

Algorithm DFS(G, v) Input graph G and a start
vertex v of G Output labeling of the edges of G
in the connected component of v Stack
S S.push(v) while S is not empty v ?
S.pop() setLabel(v, VISITED) for each edge
(v,w) out of v if w is VISITED, mark edge
BACK if w is UNEXPLORED, mark edge
DISCOVERY S.push(w)
27
Example
unexplored vertex
A
visited vertex
A
unexplored edge
discovery edge
back edge
A
D
B
E
C
28
Example (cont.)
A
A
D
B
E
D
B
E
C
C
A
A
D
B
E
D
B
E
C
C
29
DFS and Maze Traversal
  • The DFS algorithm is similar to a classic
    strategy for exploring a maze
  • We mark each intersection, corner and dead end
    (vertex) visited
  • We mark each corridor (edge) traversed
  • We keep track of the path back to the entrance
    (start vertex) by means of a rope (recursion
    stack)

30
Properties of DFS
  • Property 1
  • DFS(G, v) visits all the vertices and edges in
    the connected component of v
  • Property 2
  • The discovery edges labeled by DFS(G, v) form a
    spanning tree of the connected component of v

A
D
B
E
C
31
Analysis of DFS
  • Setting/getting a vertex/edge label takes O(1)
    time
  • Each vertex is labeled twice
  • once as UNEXPLORED
  • once as VISITED
  • Each edge is labeled twice
  • once as UNEXPLORED
  • once as DISCOVERY or BACK
  • Method incidentEdges is called once for each
    vertex
  • DFS runs in O(n m) time provided the graph is
    represented by the adjacency list structure
  • Recall that Sv deg(v) 2m

32
Applications of DFS
  • How can you find a set of plane flights to get to
    your destination from your airport?
  • How can you tell if you can fly to all
    destinations from your airport?
  • How can you find a maximal set of plane flights
    that can be cancelled while still making it
    possible to get from any city to any other?
  • If computers have multiple network connections,
    how can you prevent routing storms?

33
Path Finding
  • How to find a path between vertices u and z?
  • Call DFS(G, u) with u as the start vertex
  • We use a stack S to keep track of the path
    between the start vertex and the current vertex
  • As soon as destination vertex z is encountered,
    we return the path as the contents of the stack

Algorithm pathDFS(G, v, z) setLabel(v,
VISITED) S.push(v) if v z return
S.elements() for all e ? G.incidentEdges(v) if
getLabel(e) UNEXPLORED w ? opposite(v,e) if
getLabel(w) UNEXPLORED setLabel(e,
DISCOVERY) S.push(e) pathDFS(G, w,
z) S.pop(e) else setLabel(e,
BACK) S.pop(v)
34
Cycle Finding
Algorithm cycleDFS(G, v, z) setLabel(v,
VISITED) S.push(v) for all e ?
G.incidentEdges(v) if getLabel(e)
UNEXPLORED w ? opposite(v,e) S.push(e) if
getLabel(w) UNEXPLORED setLabel(e,
DISCOVERY) pathDFS(G, w, z) S.pop(e) else
T ? new empty stack repeat o ?
S.pop() T.push(o) until o w return
T.elements() S.pop(v)
  • How to find a cycle in a graph?
  • We use a stack S to keep track of the path
    between the start vertex and the current vertex
  • When a back edge (v, w) is encountered, return
    the cycle as the portion of the stack from the
    top to w

35
Breadth-First Search
36
Outline and Reading
  • Breadth-first search (6.3.3)
  • Algorithm
  • Example
  • Properties
  • Analysis
  • Applications
  • DFS vs. BFS (6.3.3)
  • Comparison of applications
  • Comparison of edge labels

37
Breadth-First Search
  • Breadth-first search (BFS) is a general technique
    for traversing a graph
  • A BFS traversal of a graph G
  • Visits all the vertices and edges of G
  • Determines whether G is connected
  • Computes the connected components of G
  • Computes a spanning forest of G
  • BFS on a graph with n vertices and m edges takes
    O(n m ) time
  • BFS can be further extended to solve other graph
    problems
  • Find and report a path with the minimum number of
    edges between two given vertices
  • Find a simple cycle, if there is one

38
BFS Algorithm
  • The algorithm uses a mechanism for setting and
    getting labels of vertices and edges

Algorithm BFS(G, s) L0 ? new empty
sequence L0.insertLast(s) setLabel(s, VISITED) i
? 0 while ?Li.isEmpty() Li 1 ? new empty
sequence for all v ? Li.elements() for all
e ? G.incidentEdges(v) if getLabel(e)
UNEXPLORED w ? opposite(v,e) if
getLabel(w) UNEXPLORED setLabel(e,
DISCOVERY) setLabel(w, VISITED) Li
1.insertLast(w) else setLabel(e,
CROSS) i ? i 1
Algorithm BFS(G) Input graph G Output labeling
of the edges and partition of the vertices
of G for all u ? G.vertices() setLabel(u,
UNEXPLORED) for all e ? G.edges() setLabel(e,
UNEXPLORED) for all v ? G.vertices() if
getLabel(v) UNEXPLORED BFS(G, v)
39
Example
unexplored vertex
A
visited vertex
A
unexplored edge
discovery edge
cross edge
L0
L0
A
A
L1
L1
C
B
D
C
B
D
E
F
E
F
40
Example (cont.)
41
Example (cont.)
L0
A
L1
C
B
D
L2
E
F
42
Properties
A
  • Notation
  • Gs connected component of s
  • Property 1
  • BFS(G, s) visits all the vertices and edges of
    Gs
  • Property 2
  • The discovery edges labeled by BFS(G, s) form a
    spanning tree Ts of Gs
  • Property 3
  • For each vertex v in Li
  • The path of Ts from s to v has i edges
  • Every path from s to v in Gs has at least i edges

C
B
D
E
F
L0
A
L1
C
B
D
L2
E
F
43
Analysis
  • Setting/getting a vertex/edge label takes O(1)
    time
  • Each vertex is labeled twice
  • once as UNEXPLORED
  • once as VISITED
  • Each edge is labeled twice
  • once as UNEXPLORED
  • once as DISCOVERY or CROSS
  • Each vertex is inserted once into a sequence Li
  • Method incidentEdges is called once for each
    vertex
  • BFS runs in O(n m) time provided the graph is
    represented by the adjacency list structure
  • Recall that Sv deg(v) 2m

44
Applications
  • Using the template method pattern, we can
    specialize the BFS traversal of a graph G to
    solve the following problems in O(n m) time
  • Compute the connected components of G
  • Compute a spanning forest of G
  • Find a simple cycle in G, or report that G is a
    forest
  • Given two vertices of G, find a path in G between
    them with the minimum number of edges, or report
    that no such path exists

45
DFS vs. BFS
A
C
B
D
E
F
DFS
BFS
46
DFS vs. BFS (cont.)
  • Back edge (v,w)
  • w is an ancestor of v in the tree of discovery
    edges
  • Cross edge (v,w)
  • w is in the same level as v or in the next level
    in the tree of discovery edges

A
C
B
D
E
F
DFS
BFS
47
Directed Graphs
48
Outline and Reading (6.4)
  • Reachability (6.4.1)
  • Directed DFS
  • Strong connectivity
  • Transitive closure (6.4.2)
  • The Floyd-Warshall Algorithm
  • Directed Acyclic Graphs (DAGs) (6.4.4)
  • Topological Sorting

49
Digraphs
  • A digraph is a graph whose edges are all directed
  • Short for directed graph
  • Applications
  • one-way streets
  • flights
  • task scheduling

50
Digraph Properties
  • A graph G(V,E) such that
  • Each edge goes in one direction
  • Edge (a,b) goes from a to b, but not b to a.
  • If G is simple, m lt n(n-1).
  • If we keep in-edges and out-edges in separate
    adjacency lists, we can perform listing of
    in-edges and out-edges in time proportional to
    their size.

51
Digraph Application
  • Scheduling edge (a,b) means task a must be
    completed before b can be started

ics23
ics22
ics21
ics53
ics51
ics52
ics161
ics131
ics141
ics121
ics171
The good life
ics151
52
Directed DFS
  • We can specialize the traversal algorithms (DFS
    and BFS) to digraphs by traversing edges only
    along their direction
  • In the directed DFS algorithm, we have four types
    of edges
  • discovery edges
  • back edges
  • forward edges
  • cross edges
  • A directed DFS starting at a vertex s determines
    the vertices reachable from s

E
D
C
B
A
53
Reachability
  • DFS tree rooted at v vertices reachable from v
    via directed paths

E
D
E
D
C
A
C
F
E
D
A
B
C
F
A
B
54
Strong Connectivity
  • Each vertex can reach all other vertices

55
Strong Connectivity Algorithm
  • Pick a vertex v in G.
  • Perform a DFS from v in G.
  • If theres a w not visited, print no.
  • Let G be G with edges reversed.
  • Perform a DFS from v in G.
  • If theres a w not visited, print no.
  • Else, print yes.
  • Running time O(nm).

a
G
g
c
d
e
b
f
a
g
G
c
d
e
b
f
56
Strongly Connected Components
  • Maximal subgraphs such that each vertex can reach
    all other vertices in the subgraph
  • Can also be done in O(nm) time using DFS, but is
    more complicated (similar to biconnectivity).

a , c , g
f , d , e , b
57
Transitive Closure
  • Given a digraph G, the transitive closure of G is
    the digraph G such that
  • G has the same vertices as G
  • if G has a directed path from u to v (u ? v), G
    has a directed edge from u to v
  • The transitive closure provides reachability
    information about a digraph

D
E
B
G
C
A
D
E
B
C
A
G
58
Computing the Transitive Closure
  • We can perform DFS starting at each vertex
  • O(n(nm))
  • Alternatively ... Use dynamic programming The
    Floyd-Warshall Algorithm

59
Floyd-Warshall Transitive Closure
  • Idea 1 Number the vertices 1, 2, , n.
  • Idea 2 Consider paths that use only vertices
    numbered 1, 2, , k, as intermediate vertices

Uses only vertices numbered 1,,k (add this edge
if its not already in)
i
j
Uses only vertices numbered 1,,k-1
Uses only vertices numbered 1,,k-1
k
60
Floyd-Warshalls Algorithm
Algorithm FloydWarshall(G) Input digraph
G Output transitive closure G of G i ? 1 for
all v ? G.vertices() denote v as vi i ? i
1 G0 ? G for k ? 1 to n do Gk ? Gk - 1 for
i ? 1 to n (i ? k) do for j ? 1 to n (j ? i,
k) do if Gk - 1.areAdjacent(vi, vk) ?
Gk - 1.areAdjacent(vk, vj) if
?Gk.areAdjacent(vi, vj) Gk.insertDirectedEd
ge(vi, vj , k) return Gn
  • Floyd-Warshalls algorithm numbers the vertices
    of G as v1 , , vn and computes a series of
    digraphs G0, , Gn
  • G0G
  • Gk has a directed edge (vi, vj) if G has a
    directed path from vi to vj with intermediate
    vertices in the set v1 , , vk
  • We have that Gn G
  • In phase k, digraph Gk is computed from Gk - 1
  • Running time O(n3), assuming areAdjacent is O(1)
    (e.g., adjacency matrix)

61
Floyd-Warshall Example
BOS
v
ORD
4
JFK
v
v
2
6
SFO
DFW
LAX
v
3
v
1
MIA
v
5
62
Floyd-Warshall, Iteration 1
BOS
v
ORD
4
JFK
v
v
2
6
SFO
DFW
LAX
v
3
v
1
MIA
v
5
63
Floyd-Warshall, Iteration 2
BOS
v
ORD
4
JFK
v
v
2
6
SFO
DFW
LAX
v
3
v
1
MIA
v
5
64
Floyd-Warshall, Iteration 3
BOS
v
ORD
4
JFK
v
v
2
6
SFO
DFW
LAX
v
3
v
1
MIA
v
5
65
Floyd-Warshall, Iteration 4
BOS
v
ORD
4
JFK
v
v
2
6
SFO
DFW
LAX
v
3
v
1
MIA
v
5
66
Floyd-Warshall, Iteration 5
v
ORD
4
JFK
v
v
2
6
SFO
DFW
LAX
v
3
v
1
MIA
v
5
67
Floyd-Warshall, Iteration 6
v
ORD
4
JFK
v
v
2
6
SFO
DFW
LAX
v
3
v
1
MIA
v
5
68
Floyd-Warshall, Conclusion
v
ORD
4
JFK
v
v
2
6
SFO
DFW
LAX
v
3
v
1
MIA
v
5
69
DAGs and Topological Ordering
D
E
  • A directed acyclic graph (DAG) is a digraph that
    has no directed cycles
  • A topological ordering of a digraph is a
    numbering
  • v1 , , vn
  • of the vertices such that for every edge (vi ,
    vj), we have i lt j
  • Example in a task scheduling digraph, a
    topological ordering a task sequence that
    satisfies the precedence constraints
  • Theorem
  • A digraph admits a topological ordering if and
    only if it is a DAG

B
C
A
DAG G
v4
v5
D
E
v2
B
v3
C
v1
Topological ordering of G
A
70
Topological Sorting
  • Number vertices, so that (u,v) in E implies u lt v

1
A typical student day
wake up
3
2
eat
study computer sci.
5
4
nap
more c.s.
7
play
8
write c.s. program
6
9
work out
make brownies for professors

10
11
sleep
dream about graphs
71
Algorithm for Topological Sorting
  • Note This algorithm is different from the one in
    Goodrich-Tamassia
  • Running time O(n m). How?

Method TopologicalSort(G) H ? G //
Temporary copy of G n ? G.numVertices()
while H is not empty do Let v be a vertex with
no outgoing edges Label v ? n n ? n - 1 Remove
v from H
72
Topological Sorting Algorithm using DFS
  • Simulate the algorithm by using depth-first
    search
  • O(nm) time.

Algorithm topologicalDFS(G, v) Input graph G and
a start vertex v of G Output labeling of the
vertices of G in the connected component of v
setLabel(v, VISITED) for all e ?
G.incidentEdges(v) if getLabel(e)
UNEXPLORED w ? opposite(v,e) if getLabel(w)
UNEXPLORED setLabel(e, DISCOVERY) topologica
lDFS(G, w) else e is a forward or cross
edge Label v with topological number n n ? n - 1
Algorithm topologicalDFS(G) Input dag G Output
topological ordering of G n ?
G.numVertices() for all u ? G.vertices()
setLabel(u, UNEXPLORED) for all e ? G.edges()
setLabel(e, UNEXPLORED) for all v ?
G.vertices() if getLabel(v)
UNEXPLORED topologicalDFS(G, v)
73
Topological Sorting Example
74
Topological Sorting Example
9
75
Topological Sorting Example
8
9
76
Topological Sorting Example
7
8
9
77
Topological Sorting Example
6
7
8
9
78
Topological Sorting Example
6
5
7
8
9
79
Topological Sorting Example
4
6
5
7
8
9
80
Topological Sorting Example
3
4
6
5
7
8
9
81
Topological Sorting Example
2
3
4
6
5
7
8
9
82
Topological Sorting Example
2
1
3
4
6
5
7
8
9
Write a Comment
User Comments (0)
About PowerShow.com