Tell us what’s happening:
My code should be OK, but I get teh error message:
You should update paths[node_no] to be the current path plus the neighbor node.
Your code so far
INF = float('inf')
adj_matrix = [
[0, 5, 3, INF, 11, INF],
[5, 0, 1, INF, INF, 2],
[3, 1, 0, 1, 5, INF],
[INF, INF, 1, 0, 9, 3],
[11, INF, 5, 9, 0, INF],
[INF, 2, INF, 3, INF, 0],
]
def shortest_path(matrix, start_node, target_node=None):
n = len(matrix)
distances = [INF] * n
distances[start_node] = 0
paths = [[node_no] for node_no in range(n)]
visited = [False] * n
for _ in range(n):
min_distance = INF
current = -1
for node_no in range(n):
if not visited[node_no] and distances[node_no] < min_distance:
min_distance = distances[node_no]
current = node_no
if current == -1:
break
visited[current] = True
# User Editable Region
for node_no in range(n):
distance = matrix[current][node_no]
if distance != INF and not visited[node_no]:
new_distance = distances[current] + distance
if new_distance < distances[node_no]:
distances[node_no] = new_distance
paths[node_no] = paths[current] + paths[node_no]
# User Editable Region
Your browser information:
User Agent is: Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:147.0) Gecko/20100101 Firefox/147.0
Challenge Information:
Implement the Shortest Path Algorithm - Step 19