Dynamic Programming Shortest Path Algorithm Dijkstra