ComeçarComece de graça

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

Ver curso

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 ____
Editar e executar o código