-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdijkstra.py
30 lines (29 loc) · 927 Bytes
/
dijkstra.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
import heapq
def dijkstra(graph, source, vertices):
distances = [float('inf')] * vertices
distances[source] = 0
pq = [(0, source)]
while pq:
current_distance, u = heapq.heappop(pq)
if current_distance > distances[u]:
continue
for v, weight in graph[u]:
distance = current_distance + weight
if distance < distances[v]:
distances[v] = distance
heapq.heappush(pq, (distance, v))
return distances
def print_shortest_paths(distances):
print("Vertex \tShortest Distance from Source")
for vertex, distance in enumerate(distances):
print(f"{vertex} \t\t {distance}")
graph = {
0: [(1, 4), (2, 1)],
1: [(0, 4), (2, 2), (3, 5)],
2: [(0, 1), (1, 2), (3, 8)],
3: [(1, 5), (2, 8)]
}
vertices = 4
source = 0
distances = dijkstra(graph, source, vertices)
print_shortest_paths(distances)