Shortest Path Algorithm This is called “Dijkstra’s Algorithm” …pronounced “Dirk-stra”
Problem: Find the shortest route from A to F
Step 1Label the start vertex S with a permanent label of 0 Step 2Put a temporary label on each vertex that can be reached directly from the vertex that has just received a permanent label. The temporary label must be equal to the sum of the permanent label and the weight of the arc linking it directly to the vertex. If there is already a temporary label at the vertex, it is only replaced if the new sum is smaller.
Step 3Select the minimum temporary label and make it permanent. Step 4Repeat steps 2 and 3 until the destination vertex T receives its permanent label. Step 5Trace back from T to S including an arc ABwhenever the permanent label of B permanent label of A = the weight of AB, given that B already lies on the path.
Vertex Letter Order of Selection Final Values Working Values Each vertex will have a box like the one below which has to be filled in:
Problem: Find the shortest route from A to F On the exam paper your diagram will look like this:
A B C D E F First vertex is A 1 Label 0 0 Temporary Labels 7 4 Second vertex is C 2 Label Third vertex is B 3 Label but 15 > 13 so ignore Fourth vertex is E 4 Label Fifth vertex is D 5 Label Sixth vertex is F Label Now trace back from F 16 – 13 = 3 so use DF 13 – 9 = 4 so use CD 4 – 0 = 4 so use AC Shortest Path is ACDF of length 16