-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path06_Dijstra_shortest_path.py
44 lines (30 loc) · 1.34 KB
/
06_Dijstra_shortest_path.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
import sys
def to_be_visited():
global visited_and_distance
v = -10
for index in range(number_of_vertices):
if visited_and_distance[index][0] == 0 and (v < 0 or visited_and_distance[index][1] <= visited_and_distance[v][1]):
v = index
return v
print("\nRUBAN GINO SINGH.A - URK20CS2001 | Dijkstra's algorithm for finding shortest path\n")
vertices = eval(input("Enter the Vertices: "))
# [[0, 1, 1, 0],[0, 0, 1, 0],[0, 0, 0, 1],[0, 0, 0, 0]]
edges = eval(input("Enter the Edges: "))
# [[0, 3, 4, 0],[0, 0, 0.5, 0],[0, 0, 0, 1],[0, 0, 0, 0]]
number_of_vertices = len(vertices[0])
visited_and_distance = [[0, 0]]
for i in range(number_of_vertices-1):
visited_and_distance.append([0, sys.maxsize])
for vertex in range(number_of_vertices):
to_visit = to_be_visited()
for neighbor_index in range(number_of_vertices):
if vertices[to_visit][neighbor_index] == 1 and visited_and_distance[neighbor_index][0] == 0:
new_distance = visited_and_distance[to_visit][1] + edges[to_visit][neighbor_index]
if visited_and_distance[neighbor_index][1] > new_distance:
visited_and_distance[neighbor_index][1] = new_distance
visited_and_distance[to_visit][0] = 1
i = 0
print(" ")
for distance in visited_and_distance:
print("The shortest distance of ",chr(ord('a') + i), " from the source vertex a is:",distance[1])
i = i + 1