Ich habe eine Adjazenzmatrix D unten. Wie schreibe ich eine Python-Funktion, die True zurückgibt, wenn alle Scheitelpunkte in der Matrix verbunden sind, oder False, wenn nicht?Python-Funktion: Auf Konnektivität in Adjazenzmatrix prüfen
D = [['a', 'c', 'g', 'w', 'Q', 'f', 'Z', 't', 'R'], [0, 1, 2, 1, 9, 0, 0, 0, 0], [1, 0, 3, 4, 0, 0, 0, 0, 0], [2, 3, 0, 15, 2, 0, 0, 0, 0], [1, 4, 15, 0, 7, 0, 0, 0, 0], [9, 0, 2, 7, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 2, 9, 0], [0, 0, 0, 0, 0, 2, 0, 0, 20], [0, 0, 0, 0, 0, 9, 0, 0, 0], [0, 0, 0, 0, 0, 0, 20, 0, 0]]
def connectivity(adjMatrix):
connected = True
while connected == True:
# some algorithm that checks that each vertex can be connected to any other vertex
# if connected -> remains True
# if not connected -> False
return connected
print(connectivity(D))
Dies ist ein gut verstandenes Thema. Sie sollten leicht einen effizienten Algorithmus dafür mit einer schnellen Suche finden können. –