刘凡 3282579ec1 first commit | 2 rokov pred | |
---|---|---|
.. | ||
README.md | 2 rokov pred | |
dijsktras.py | 2 rokov pred | |
input.txt | 2 rokov pred |
Input is taken from the file
Sample input
5
0 2 7 -1 -1
-1 0 3 8 5
-1 2 0 1 -1
-1 -1 -1 0 4
-1 -1 -1 5 0
0
First line contains the number of nodes,say n.(Nodes are numbered as 0,1,2,...(n-1) ) Followed by n*n weighted matrix. Disconnected egdes are represented by negative weight. Last line contains the source node.(i.e, the node from which the rest of the nodes should be reached)
Graph is first drawn from the weighted matrix input from the user with weights shown. Edges are marked with black.
DDijkstra's algorithm is an algorithm for finding the shortest paths between nodes in a graph.
Here, given the source node, the algorithm finds the shortest path from the source node to each of the remaining nodes.
To understand this better, consider the above input. Source node is 0.
The graph, initially.
We use the following 3 lists:
dist[i] will hold the shortest distance from source to i.
parent[i] will hold the node from which node i is reached to, in the shortest path from source.
sptSet[i] will hold true if vertex i is included in shortest path tree.
dist = [0, inf ,inf, inf, inf]
parent = [-1, None, None, None]
sptSet = [True, False, False, False, False]
Node 1 and Node 2 can be reached directly from source node,i.e, 0 with a distance of 2 and 7 respectively. Hence they are updated accordingly.
dist = [0, 2, 7, inf, inf]
parent = [-1, 0, 0, None, None]
sptSet = [True, False, False, False, False]
Minimum most distance of those where sptSet[i] == False, is node 1. Hence, the node is now included in the shorted path tree, hence sptSet[1] is set to True.
dist = [0, 2, 5, 10, 7]
parent = [-1, 0, 1, 1, 1]
sptSet = [True, True, False, False, False]
dist = [0, 2, 5, 6, 7]
parent = [-1, 0, 1, 2, 1]
sptSet = [True, True, True, False, False]
dist = [0, 2, 5, 6, 7]
parent = [-1, 0, 1, 2, 1]
sptSet = [True, True, True, True, False]
Here, the red edges denote the shortest path from source node to the rest of the nodes.
Time : O(V^2)
V - number of Vertices