Section 7: Dijkstra’s & Midterm Postmortem

Slides:



Advertisements
Similar presentations
Single Source Shortest Paths
Advertisements

CSE 390B: Graph Algorithms Based on CSE 373 slides by Jessica Miller, Ruth Anderson 1.
© DEEDS 2008Graph Algorithms1 Remarks on Dijkstra  Determining the minimum marginal element (code line: v = the vertex in M 2 with minimum v.L; ) accounts.
CSE 101- Winter ‘15 Discussion Section January 26th 2015.
CS 206 Introduction to Computer Science II 11 / 07 / 2008 Instructor: Michael Eckmann.
CSE332: Data Abstractions Lecture 17: Shortest Paths Dan Grossman Spring 2010.
Tirgul 12 Algorithm for Single-Source-Shortest-Paths (s-s-s-p) Problem Application of s-s-s-p for Solving a System of Difference Constraints.
1 8-ShortestPaths Shortest Paths in a Graph Fundamental Algorithms.
CS 206 Introduction to Computer Science II 11 / 05 / 2008 Instructor: Michael Eckmann.
More Graph Algorithms Weiss ch Exercise: MST idea from yesterday Alternative minimum spanning tree algorithm idea Idea: Look at smallest edge not.
Dijkstra’s Algorithm Slide Courtesy: Uwash, UT 1.
Nirmalya Roy School of Electrical Engineering and Computer Science Washington State University Cpt S 223 – Advanced Data Structures Graph Algorithms: Minimum.
Dijkstras Algorithm Named after its discoverer, Dutch computer scientist Edsger Dijkstra, is an algorithm that solves the single-source shortest path problem.
CSE373: Data Structures & Algorithms Lecture 17: Shortest Paths Nicki Dell Spring 2014.
CSE332: Data Abstractions Lecture 17: Shortest Paths Dan Grossman Spring 2012.
CSE373: Data Structures & Algorithms Lecture 17: Dijkstra’s Algorithm Lauren Milne Summer 2015.
SLIDES ADAPTED FROM ALEX MARIAKAKIS, WITH MATERIAL FROM KRYSTA YOUSOUFIAN, MIKE ERNST, KELLEN DONOHUE Section 5: HW6 and Interfaces Justin Bare and Deric.
WEEK 12 Graphs IV Minimum Spanning Tree Algorithms.
CSE373: Data Structures & Algorithms Lecture 19: Dijkstra’s algorithm and Spanning Trees Catie Baker Spring 2015.
TIRGUL 10 Dijkstra’s algorithm Bellman-Ford Algorithm 1.
CSE 373: Data Structures and Algorithms Lecture 21: Graphs V 1.
Graphs – Part III CS 367 – Introduction to Data Structures.
Section 7: Dijkstra’s Justin Bare and deric Pang
Shortest Paths.
Instructor: Lilian de Greef Quarter: Summer 2017
CSE 373: Data Structures & Algorithms Graph Traversals: Dijkstra’s
Minimum Spanning Trees
CSE373: Data Structures & Algorithms Lecture 19: Spanning Trees
Cse 373 May 8th – Dijkstras.
Instructor: Lilian de Greef Quarter: Summer 2017
Instructor: Lilian de Greef Quarter: Summer 2017
Section 5: HW6 and Interfaces
CSE373: Data Structures & Algorithms Lecture 17: Shortest Paths
Short paths and spanning trees
Section 5: HW6 and Interfaces
Why do Java programmers wear glasses?
What do you call 8 Hobbits?
Greedy Algorithms / Dijkstra’s Algorithm Yin Tat Lee
CSE373: Data Structures & Algorithms Lecture 12: Minimum Spanning Trees Catie Baker Spring 2015.
Shortest Paths.
CSE373: Data Structures & Algorithms Lecture 20: Minimum Spanning Trees Linda Shapiro Spring 2016.
CSE 373 Data Structures and Algorithms
CSE373: Data Structures & Algorithms Lecture 18: Dijkstra’s Algorithm
CSE 373: Data Structures and Algorithms
Lecture 13 Algorithm Analysis
Lecture 13 Algorithm Analysis
Based on slides of Dan Suciu
Lecture 13 Algorithm Analysis
CSE332: Data Abstractions Lecture 18: Minimum Spanning Trees
Slide Courtesy: Uwash, UT
Section 5: HW6 and Interfaces
Lecture 13 Algorithm Analysis
Fundamental Data Structures and Algorithms
CSE 373: Data Structures and Algorithms
CSE 373: Data Structures and Algorithms
Weighted Graphs & Shortest Paths
Section 5: HW6 and Interfaces
CSE332: Data Abstractions Lecture 17: Shortest Paths
CSE 373 Data Structures and Algorithms
Slide Courtesy: Uwash, UT
Shortest Paths.
CSE 417: Algorithms and Computational Complexity
CSE 373: Data Structures and Algorithms
CSE 373: Data Structures and Algorithms
Topological Sorting Minimum Spanning Trees Shortest Path
INTRODUCTION A graph G=(V,E) consists of a finite non empty set of vertices V , and a finite set of edges E which connect pairs of vertices .
Presentation transcript:

Section 7: Dijkstra’s & Midterm Postmortem Slides adapted from Alex Mariakakis, with material Kellen Donohue, David Mailhot, and Dan Grossman

Agenda How to weight your edges Dijkstra’s algorithm Midterm Q&A

Homework 7 Modify your graph to use generics Will have to update HW #5 and HW #6 tests Implement Dijkstra’s algorithm Search algorithm that accounts for edge weights Note: This should not change your implementation of Graph. Dijkstra’s is performed on a Graph, not within a Graph. The more well-connected two characters are, the lower the weight and the more likely that a path is taken through them The weight of an edge is equal to the inverse of how many comic books the two characters share Ex: If Carol Danvers and Luke Cage appeared in 5 comic books together, the weight of their edge would be 1/5 No duplicate edges

Review: Shortest Paths with BFS 1 From Node B A Destination Path Cost A <B,A> 1 B <B> C <B,A,C> 2 D <B,D> E <B,D,E> 1 1 1 C 1 D 1 1 E

Shortest Paths with Weights B 2 From Node B A Destination Path Cost A <B,A> 2 B <B> C <B,A,C> 5 D <B,A,C,D> 7 E <B,A,C,E> 100 100 3 C 2 D 2 6 E Paths are not the same!

BFS vs. Dijkstra’s 1 500 100 1 5 -10 BFS doesn’t work because path with minimal cost ≠ path with fewest edges Dijkstra’s works if the weights are non-negative What happens if there is a negative edge? Minimize cost by repeating the cycle forever Add constant weight to all edges until positive

Dijkstra’s Algorithm Named after its inventor Edsger Dijkstra (1930-2002) Turing Award winner and all-around amazing computer scientist Other work includes Banker’s algorithm, semaphores The idea: reminiscent of BFS, but adapted to handle weights Grow the set of nodes whose shortest distance has been computed Nodes not in the set will have a “best distance so far” A priority queue will turn out to be useful for efficiency

Dijkstra’s Algorithm For each node v, set v.cost = ∞ and v.known = false Set source.cost = 0 While there are unknown nodes in the graph Select the unknown node v with lowest cost Mark v as known For each edge (v,u) with weight w, c1 = v.cost + w c2 = u.cost if(c1 < c2) u.cost = c1 u.path = v // cost of best path through v to u // cost of best path to u previously known // if the new path through v is better, update

Example #1    2 2 3 B A F H 1 2 1 5 10 4 9 3 G   C 2 11 D 1  E 7   2 2 3 B A F H 1 2 1 5 10 4 9 3 G   C 2 11 D 1  E vertex known? cost path A Y B ∞ C D E F G H 7  Order Added to Known Set:

Example #1 2   2 2 3 B A F H 1 2 1 5 10 4 9 3 G  1 C 2 11 D 1 4 E vertex known? cost path A Y B ≤ 2 C ≤ 1 D ≤ 4 E ∞ F G H 7  Order Added to Known Set: A

Example #1 2   2 2 3 B A F H 1 2 1 5 10 4 9 3 G  1 C 2 11 D 1 4 E vertex known? cost path A Y B ≤ 2 C 1 D ≤ 4 E ∞ F G H 7  Order Added to Known Set: A, C

Example #1 2   2 2 3 B A F H 1 2 1 5 10 4 9 3 G  1 C 2 11 D 1 4 E vertex known? cost path A Y B ≤ 2 C 1 D ≤ 4 E ≤ 12 F ∞ G H 7 12 Order Added to Known Set: A, C

Example #1 2   2 2 3 B A F H 1 2 1 5 10 4 9 3 G  1 C 2 11 D 1 4 E vertex known? cost path A Y B 2 C 1 D ≤ 4 E ≤ 12 F ∞ G H 7 12 Order Added to Known Set: A, C, B

Example #1 2 4  2 2 3 B A F H 1 2 1 5 10 4 9 3 G  1 C 2 11 D 1 4 E vertex known? cost path A Y B 2 C 1 D ≤ 4 E ≤ 12 F G ∞ H 7 12 Order Added to Known Set: A, C, B

Example #1 2 4  2 2 3 B A F H 1 2 1 5 10 4 9 3 G  1 C 2 11 D 1 4 E vertex known? cost path A Y B 2 C 1 D 4 E ≤ 12 F ≤ 4 G ∞ H 7 12 Order Added to Known Set: A, C, B, D

Example #1 2 4  2 2 3 B A F H 1 2 1 5 10 4 9 3 G  1 C 2 11 D 1 4 E vertex known? cost path A Y B 2 C 1 D 4 E ≤ 12 F G ∞ H 7 12 Order Added to Known Set: A, C, B, D, F

Example #1 2 4 7 2 2 3 B A F H 1 2 1 5 10 4 9 3 G  1 C 2 11 D 1 4 E vertex known? cost path A Y B 2 C 1 D 4 E ≤ 12 F G ∞ H ≤ 7 7 12 Order Added to Known Set: A, C, B, D, F

Example #1 2 4 7 2 2 3 B A F H 1 2 1 5 10 4 9 3 G  1 C 2 11 D 1 4 E vertex known? cost path A Y B 2 C 1 D 4 E ≤ 12 F G ∞ H 7 7 12 Order Added to Known Set: A, C, B, D, F, H

Example #1 2 4 7 2 2 3 B A F H 1 2 1 5 10 4 9 3 G 8 1 C 2 11 D 1 4 E vertex known? cost path A Y B 2 C 1 D 4 E ≤ 12 F G ≤ 8 H 7 7 12 Order Added to Known Set: A, C, B, D, F, H

Example #1 2 4 7 2 2 3 B A F H 1 2 1 5 10 4 9 3 G 8 1 C 2 11 D 1 4 7 E vertex known? cost path A Y B 2 C 1 D 4 E ≤ 12 F G 8 H 7 12 Order Added to Known Set: A, C, B, D, F, H, G

Example #1 2 4 7 2 2 3 B A F H 1 2 1 5 10 4 9 3 G 8 1 C 2 11 D 1 4 7 E vertex known? cost path A Y B 2 C 1 D 4 E ≤ 11 G F 8 H 7 11 Order Added to Known Set: A, C, B, D, F, H, G

Example #1 2 4 7 2 2 3 B A F H 1 2 1 5 10 4 9 3 G 8 1 C 2 11 D 1 4 E vertex known? cost path A Y B 2 C 1 D 4 E 11 G F 8 H 7 7 11 Order Added to Known Set: A, C, B, D, F, H, G, E

Interpreting the Results A B D C F H E G 2 4 7 1 11 8 3 10 9 5 vertex known? cost path A Y B 2 C 1 D 4 E 11 G F 8 H 7 2 2 3 B A F H 1 1 4 3 G C D E

Example #2  2 B A 1  1 5 2 E  1 D 1 3 5 C   6 2 G  10 F 2 B A 1  1 5 2 E  1 D 1 3 5 C   6 2 G vertex known? cost path A Y B ∞ C D E F G  10 F Order Added to Known Set:

Example #2 3 2 B A 1 2 1 5 2 E 1 1 D 1 3 5 C 2 6 6 2 G vertex known? cost path A Y B 3 E C 2 D 1 F 4 G 6 4 10 F Order Added to Known Set: A, D, C, E, B, F, G

Pseudocode Attempt #1 dijkstra(Graph G, Node start) { for each node: x.cost=infinity, x.known=false start.cost = 0 while(not all nodes are known) { b = dequeue b.known = true for each edge (b,a) in G { if(!a.known) { if(b.cost + weight((b,a)) < a.cost){ a.cost = b.cost + weight((b,a)) a.path = b } brackets… O(|V|) O(|V|2) O(V^2) = O(V + V-1 + V-2 + …) = O (V*(V+1)/2) O(|E|) O(|V|2)

Can We Do Better? Increase efficiency by considering lowest cost unknown vertex with sorting instead of looking at all vertices PriorityQueue is like a queue, but returns elements by lowest value instead of FIFO

Priority Queue Increase efficiency by considering lowest cost unknown vertex with sorting instead of looking at all vertices PriorityQueue is like a queue, but returns elements by lowest value instead of FIFO Two ways to implement: Comparable class Node implements Comparable<Node> public int compareTo(other) Comparator class NodeComparator extends Comparator<Node> new PriorityQueue(new NodeComparator())

Pseudocode Attempt #2 dijkstra(Graph G, Node start) { for each node: x.cost=infinity, x.known=false start.cost = 0 build-heap with all nodes while(heap is not empty) { b = deleteMin() if (b.known) continue; b.known = true for each edge (b,a) in G { if(!a.known) { add(b.cost + weight((b,a)) ) } brackets… O(|V|) O(|V|log|V|) O(|E|log|V|) O(|E|log|V|)

Proof of Correctness All the “known” vertices have the correct shortest path through induction Initially, shortest path to start node has cost 0 If it stays true every time we mark a node “known”, then by induction this holds and eventually everything is “known” with shortes path Key fact: When we mark a vertex “known” we won’t discover a shorter path later Remember, we pick the node with the min cost each round Once a node is marked as “known”, going through another path will only add weight Only true when node weights are positive

Midterm questions!

Midterm Question 6 B B D A C E A. @returns some number between x − 10 and x + 10 B. @returns some number between x − 5 and x + 5 C. @requires x > 0 @returns some number between x − 5 and x + 5 D. @requires x > 0 or x < −5 E. @requires x > 0 @throws IllegalArgument if x > 100 @returns some number between x − 10 and x + 10 strongest B B D A C E weakest