Caminho mais curto III
Este é o último exercício deste trio! Agora você vai concluir o problema escrevendo o código que retorna False se não houver caminho entre dois nós.
Este exercício faz parte do curso
Introdução à Análise de Redes em Python
Instruções do exercício
- Verifique se a fila foi esvaziada. Você pode fazer isso inspecionando o último elemento de queue com
[-1]. - Coloque a instrução de retorno apropriada para indicar se há um caminho entre esses dois nós.
Exercício interativo prático
Experimente este exercício completando este código de exemplo.
def path_exists(G, node1, node2):
"""
This function checks whether a path exists between two nodes (node1, node2) in graph G.
"""
visited_nodes = set()
queue = [node1]
for node in queue:
neighbors = list(G.neighbors(node))
if node2 in neighbors:
print('Path exists between nodes {0} and {1}'.format(node1, node2))
return True
break
else:
visited_nodes.add(node)
queue.extend([n for n in neighbors if n not in visited_nodes])
# Check to see if the final element of the queue has been reached
if node == ____:
print('Path does not exist between nodes {0} and {1}'.format(node1, node2))
# Place the appropriate return statement
return ____