1 / 30

Slides by Alex Mariakakis with material Kellen Donohue, David Mailhot , and Dan Grossman

Section 7: Dijkstra’s. Slides by Alex Mariakakis with material Kellen Donohue, David Mailhot , and Dan Grossman. Agenda. How to weight your edges Dijkstra’s a lgorithm. Homework 7. Modify your graph to use generics Will have to update HW #5 and HW #6 tests

camdyn
Download Presentation

Slides by Alex Mariakakis with material Kellen Donohue, David Mailhot , and Dan Grossman

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Section 7:Dijkstra’s Slides by Alex Mariakakis with material Kellen Donohue, David Mailhot, and Dan Grossman

  2. Agenda • How to weight your edges • Dijkstra’salgorithm

  3. 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 withina 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 Amazing Amoeba and Zany Zebra appeared in 5 comic books together, the weight of their edge would be 1/5 • No duplicate edges

  4. Review: Shortest Paths with BFS B 1 From Node B A 1 1 1 C D 1 1 1 E

  5. Shortest Paths with Weights B 2 From Node B A 100 100 3 C D 2 6 2 E Paths are not the same!

  6. BFS vs. Dijkstra’s • 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 100 100 1 100 100 1 5 -10 500

  7. Dijkstra’s Algorithm • Named after its inventor EdsgerDijkstra (1930-2002) • Truly one of the “founders” of computer science; this is just one of his many contributions • 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

  8. 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

  9. Example #1    0 2 2 3 B A F H 1 2 1 5 10 4 9 3  G  C 2 11 D 1  E  7 Order Added to Known Set:

  10. Example #1 2   0 2 2 3 B A F H 1 2 1 5 10 4 9 3  G 1 C 2 11 D 1 4 E  7 Order Added to Known Set: A

  11. Example #1 2   0 2 2 3 B A F H 1 2 1 5 10 4 9 3  G 1 C 2 11 D 1 4 E  7 Order Added to Known Set: A, C

  12. Example #1 2   0 2 2 3 B A F H 1 2 1 5 10 4 9 3  G 1 C 2 11 D 1 4 E 12 7 Order Added to Known Set: A, C

  13. Example #1 2   0 2 2 3 B A F H 1 2 1 5 10 4 9 3  G 1 C 2 11 D 1 4 E 12 7 Order Added to Known Set: A, C, B

  14. Example #1 2 4  0 2 2 3 B A F H 1 2 1 5 10 4 9 3  G 1 C 2 11 D 1 4 E 12 7 Order Added to Known Set: A, C, B

  15. Example #1 2 4  0 2 2 3 B A F H 1 2 1 5 10 4 9 3  G 1 C 2 11 D 1 4 E 12 7 Order Added to Known Set: A, C, B, D

  16. Example #1 2 4  0 2 2 3 B A F H 1 2 1 5 10 4 9 3  G 1 C 2 11 D 1 4 E 12 7 Order Added to Known Set: A, C, B, D, F

  17. Example #1 2 4 7 0 2 2 3 B A F H 1 2 1 5 10 4 9 3  G 1 C 2 11 D 1 4 E 12 7 Order Added to Known Set: A, C, B, D, F

  18. Example #1 2 4 7 0 2 2 3 B A F H 1 2 1 5 10 4 9 3  G 1 C 2 11 D 1 4 E 12 7 Order Added to Known Set: A, C, B, D, F, H

  19. Example #1 2 4 7 0 2 2 3 B A F H 1 2 1 5 10 4 9 3 8 G 1 C 2 11 D 1 4 E 12 7 Order Added to Known Set: A, C, B, D, F, H

  20. Example #1 2 4 7 0 2 2 3 B A F H 1 2 1 5 10 4 9 3 8 G 1 C 2 11 D 1 4 7 E 12 Order Added to Known Set: A, C, B, D, F, H, G

  21. Example #1 2 4 7 0 2 2 3 B A F H 1 2 1 5 10 4 9 3 8 G 1 C 2 11 D 1 4 7 E 11 Order Added to Known Set: A, C, B, D, F, H, G

  22. Example #1 2 4 7 0 2 2 3 B A F H 1 2 1 5 10 4 9 3 8 G 1 C 2 11 D 1 4 E 11 7 Order Added to Known Set: A, C, B, D, F, H, G, E

  23. Interpreting the Results 2 4 7 0 2 2 3 B A F H 1 2 1 5 10 4 9 8 G 3 1 C 2 11 D 1 4 E 11 7 2 2 3 B A F H 1 1 4 G 3 C D E

  24. Example #2  0 2 B A 1  1 5 2 E  1 D 1 3 5 C   6 G 2  10 F Order Added to Known Set:

  25. Example #2 3 0 2 B A 1 2 1 5 2 E 1 1 D 3 1 5 C 2 6 6 G 2 4 10 F Order Added to Known Set: A, D, C, E, B, F, G

  26. 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(|E|) O(|V|2)

  27. 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

  28. 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())

  29. 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|)

  30. 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

More Related