Graphs: shortest paths - PowerPoint PPT Presentation

About This Presentation
Title:

Graphs: shortest paths

Description:

However, Dijkstra's always visits the vertex with the smallest distance next, so ... Certainly this is a generalization of Dijkstra's. ... – PowerPoint PPT presentation

Number of Views:41
Avg rating:3.0/5.0
Slides: 51
Provided by: anand4
Learn more at: http://www.cs.cmu.edu
Category:

less

Transcript and Presenter's Notes

Title: Graphs: shortest paths


1
Graphs shortest paths Minimum Spanning
Tree(MST)
  • 15-211 Fundamental Data
    Structures and Algorithms

Ananda Guna April 8, 2003
2
Announcements
  • Homework 5 is due Tuesday April 15th.
  • Quiz 3 feedback is enabled.
  • Final Exam is Tuesday May 8th at 8AM

3
Recap
4
Dijkstras algorithm
  • S 1
  • for i 2 to n do Di C1,i if there is an
    edge from 1 to i, infinity otherwise
  • for i 1 to n-1
  • choose a vertex w in V-S such that Dw is min
  • add w to S (where S is the set of visited
    nodes)
  • for each vertex v in V-S do
  • Dv min(Dv, Dwcw,v)
  • Where V n

5
Features of Dijkstras Algorithm
  • A greedy algorithm
  • Visits every vertex only once, when it becomes
    the vertex with minimal distance amongst those
    still in the priority queue
  • Distances may be revised multiple times current
    values represent best guess based on our
    observations so far
  • Once a vertex is visited we are guaranteed to
    have found the shortest path to that vertex. why?

6
Correctness (via contradiction)
  • Prove D(u) represent the shortest path to u
    (visited node)
  • Assume u is the first vertex visited such that
    D(u) is not a shortest path (thus the true
    shortest path to u must pass through some
    unvisited vertex)
  • Let x represent the first unvisited vertex on the
    true shortest path to u
  • D(x) must represent a shortest path to x, and
    D(x) ? Dshortest(u).
  • However, Dijkstras always visits the vertex with
    the smallest distance next, so we cant possibly
    visit u before we visit x

7
Quiz break
  • Would it be better to use an adjacency list or an
    adjacency matrix for Dijkstras algorithm?
  • What is the running time of Dijkstras algorithm,
    in terms of V and E in each case?

8
Complexity of Dijkstra
  • Adjacency matrix version Dijkstra finds shortest
    path from one vertex to all others in O(V2)
    time
  • If E is small compared to V2, use a priority
    queue to organize the vertices in V-S, where V is
    the set of all vertices and S is the set that has
    already been explored
  • So total of E updates each at a cost of O(log
    V)
  • So total time is O(E logV)

9
Negative Weighted Single-Source Shortest Path
Algorithm (Bellman-Ford Algorithm)
10
The Bellman-Ford algorithm
(see Weiss, Section 14.4)
  • Returns a boolean
  • TRUE if and only if there is no negative-weight
    cycle reachable from the source a simple cycle
    ltv0, v1,,vkgt, where v0vk and
  • FALSE otherwise
  • If it returns TRUE, it also produces the shortest
    paths

11
Example
  • For each edge (u,v), let's denote its length by
    C(u,v))
  • Let div distance from start to v using the
    shortest path out of all those that use i or
    fewer edges, or infinity if you can't get there
    with lt i edges.

12
Example ctd..
  • How can we fill out the rows?

V
0 1 2 3 4 5
0 0 ? ? ? ? ?
1 0 50 ? 15 ? ?
2 0 50 80 15 45 ?
i
13
Example ctd..
  • Can we get ith row from i-1th row?
  • for v ! start,
  • dvi MIN dxi-1 len(x,v)
  • x-gtv
  • We know minimum path to come to x using lt i
    nodes.So for all x that can reach v, find the
    minimum such sum (in blue) among all x
  • Assume dstarti 0 for all i

14
Completing the table
dvi MIN dxi-1 len(x,v)
x-gtv
0 1 2 3 4 5
0 0 ? ? ? ? ?
1 0 50 ? 15 ? ?
2 0 50 80 15 45 ?
3 0 25 80 15 45 75
4 0 25 55 15 45 75
5 0 25 55 15 45 65
15
Key features
  • If the graph contains no negative-weight cycles
    reachable from the source vertex, after V - 1
    iterations all distance estimates represent
    shortest pathswhy?

16
Correctness
Case 1 Graph G(V,E) doesnt contain any
negative-weight cycles reachable from the source
vertex s Consider a shortest path p lt v0,
v1,..., vkgt, which must have k ? V - 1 edges
  • By induction
  • D(s) 0 after initialization
  • Assume D(vi-1) is a shortest path after iteration
    (i-1)
  • Since edge (vi-1,vi) is updated on the ith pass,
    D(vi) must then reflect the shortest path to vi.
  • Since we perform V - 1 iterations, D(vi) for
    all reachable vertices vi must now represent
    shortest paths
  • The algorithm will return true because on the
    Vth iteration, no distances will change

17
Correctness
Case 2 Graph G(V,E) contains a negative-weight
cycle lt v0, v1,..., vkgt reachable from the
source vertex s
  • Proof by contradiction
  • Assume the algorithm returns TRUE
  • Thus, D(vi-1) weight(vi-1, vi) ? D(vi) for i
    1,,k
  • Summing the inequalities for the cycle
  • leads to a contradiction since the first sums on
    each side are equal (each vertex appears exactly
    once) and the sum of weights must be less than 0.

18
Performance
19
The All Pairs Shortest Path Algorithm (Floyds
Algorithm)
20
Finding all pairs shortest paths
  • Assume G(V,E) is a graph such that cv,w ? 0,
    where C is the matrix of edge costs.
  • Find for each pair (v,w), the shortest path from
    v to w. That is, find the matrix of shortest
    paths
  • Certainly this is a generalization of Dijkstras.
  • Note For later discussions assume V n and
    E m

21
Floyds Algorithm
  • Aij C(i,j) if there is an edge (i,j)
  • Aij infinity(inf) if there is no edge
    (i,j)

Graph
adjacency matrix
A is the shortest path matrix that uses 1 or
fewer edges
22
Floyd ctd..
  • To find shortest paths that uses 2 or fewer edges
    find A2, where multiplication defined as min of
    sums instead sum of products
  • That is (A2)ij min Aik Akj k 1..n
  • This operation is O(n3)
  • Using A2 you can find A4 and then A8 and so on
  • Therefore to find An we need log n operations
  • Therefore this algorithm is O(log n n3)
  • We will consider another algorithm next

23
Floyd-Warshall Algorithm
  • This algorithm uses nxn matrix A to compute the
    lengths of the shortest paths using a dynamic
    programming technique.
  • Let Ai,j ci,j for all i,j i?j
  • If (i,j) is not an edge, set Ai,jinfinity and
    Ai,i0
  • Aki,j
  • min (Ak-1i,j , Ak-1i,k Ak-1k,j)

Where Ak is the matrix after k-th iteration and
path from i to j does not pass through a vertex
higher than k
24
Example Floyd-Warshall Algorithm
Find the all pairs shortest path matrix
8
2
1
2
3
3
5
  • Aki,j
  • min (Ak-1i,j , Ak-1i,k Ak-1k,j)

Where Ak is the matrix after k-th iteration and
path from i to j does not pass through a vertex
higher than k
25
Floyd-Warshall Implementation
  • initialize Ai,j Ci,j
  • initialize all Ai,i 0
  • for k from 1 to n
  • for i from 1 to n
  • for j from 1 to n
  • if (Ai,j gt Ai,kAk,j)
  • Ai,j Ai,kAk,j
  • The complexity of this algorithm is O(n3)

26
Questions
  • Question What is the asymptotic run time of
    Dijkstra (adjacency matrix version)?
  • O(n2)
  • Question What is the asymptotic running time of
    Floyd-Warshall?

27
Minimum Spanning Trees
(some material adapted from slides by Peter Lee)
28
Problem Laying Telephone Wire
Central office
29
Wiring Naïve Approach
Central office
Expensive!
30
Wiring Better Approach
Central office
Minimize the total length of wire connecting the
customers
31
Minimum Spanning Tree (MST)
(see Weiss, Section 24.2.2)
A minimum spanning tree is a subgraph of an
undirected weighted graph G, such that
  • it is a tree (i.e., it is acyclic)
  • it covers all the vertices V
  • contains V - 1 edges
  • the total cost associated with tree edges is the
    minimum among all possible spanning trees
  • not necessarily unique

32
Applications of MST
  • Any time you want to visit all vertices in a
    graph at minimum cost (e.g., wire routing on
    printed circuit boards, sewer pipe layout, road
    planning)
  • Internet content distribution
  • , also a hot research topic
  • Idea publisher produces web pages, content
    distribution network replicates web pages to many
    locations so consumers can access at higher speed
  • MST may not be good enough!
  • content distribution on minimum cost tree may
    take a long time!

33
How Can We Generate a MST?
34
Prims Algorithm
  • Let V 1,2,..,n and U be the set of vertices
    that makes the MST and T be the MST
  • Initially U 1 and T ?
  • while (U ? V)
  • let (u,v) be the lowest cost edge such that
  • u? U and v ? V-U
  • T T ? (u,v)
  • U U ? v

35
Prims Algorithm implementation
Initialization a. Pick a vertex r to be the
root b. Set D(r) 0, parent(r) null c. For
all vertices v ? V, v ? r, set D(v) ? d.
Insert all vertices into priority queue P,
using distances as the keys
Vertex Parent e -
36
Prims Algorithm
While P is not empty 1. Select the next vertex
u to add to the tree u P.deleteMin() 2.
Update the weight of each vertex w adjacent to
u which is not in the tree (i.e., w ? P) If
weight(u,w) lt D(w), a. parent(w) u b.
D(w) weight(u,w) c. Update the priority
queue to reflect new distance for w
37
Prims algorithm
Vertex Parent e - b e c e d e
9
b
a
6
2
d
4
5
4
5
e
5
c
The MST initially consists of the vertex e, and
we update the distances and parent for its
adjacent vertices
38
Prims algorithm
Vertex Parent e - b e c d d e a d
9
b
a
6
2
a
c
b
d
4
5
2
4
5
4
5
e
5
c
39
Prims algorithm
Vertex Parent e - b e c d d e a d
9
b
a
6
2
c
b
d
4
5
4
5
4
5
e
5
c
40
Prims algorithm
Vertex Parent e - b e c d d e a d
9
b
a
6
2
b
d
4
5
5
4
5
e
5
c
41
Prims algorithm
Vertex Parent e - b e c d d e a d
The final minimum spanning tree
42
Prims Algorithm Invariant
  • At each step, we add the edge (u,v) s.t. the
    weight of (u,v) is minimum among all edges where
    u is in the tree and v is not in the tree
  • Each step maintains a minimum spanning tree of
    the vertices that have been included thus far
  • When all vertices have been included, we have a
    MST for the graph!

43
Running time of Prims algorithm
44
Another Approach Kruskals
  • Create a forest of trees from the vertices
  • Repeatedly merge trees by adding safe edges
    until only one tree remains
  • A safe edge is an edge of minimum weight which
    does not create a cycle

forest a, b, c, d, e
45
Kruskals algorithm
Initialization a. Create a set for each vertex v
? V b. Initialize the set of safe edges A
comprising the MST to the empty set c. Sort
edges by increasing weight
a, b, c, d, e A ? E (a,d), (c,d),
(d,e), (a,c), (b,e), (c,e), (b,d), (a,b)
46
Kruskals algorithm
For each edge (u,v) ? E in increasing order while
more than one set remains If u and v, belong to
different sets a. A A ? (u,v) b. merge
the sets containing u and v Return A
  • Use Union-Find algorithm to efficiently determine
    if u and v belong to different sets

47
Kruskals algorithm
E (a,d), (c,d), (d,e), (a,c), (b,e),
(c,e), (b,d), (a,b)
48
Kruskals Algorithm Invariant
  • After each iteration, every tree in the forest is
    a MST of the vertices it connects
  • Algorithm terminates when all vertices are
    connected into one tree

49
Greedy Approach
  • Like Dijkstras algorithm, both Prims and
    Kruskals algorithms are greedy algorithms
  • The greedy approach works for the MST problem
    however, it does not work for many other problems!

50
Thursday
  • P vs NP
  • Models of Hard Problems
  • Work on Homework 5
Write a Comment
User Comments (0)
About PowerShow.com