Python :: Aufgabe #344 :: Lösung #1
3 Lösungen

#344
Prüfen auf Toeplitz-Matrix
Fortgeschrittener - Python
von JKooP
- 16.04.2021 um 17:07 Uhr
Von einer Toeplitz-Matrix spricht man, wenn alle Diagonalen von links oben nach rechts unten die gleichen Zahlen enthalten.
Beispiel 1:
matrix = { {4, 5, 6, 7, 8}, {3, 4, 5, 6, 7 }, {2, 3, 4, 5, 6}, {1, 2, 3, 4, 5} }
Lösung: wahr, denn alle Diagonalen enthalten die gleichen Zahlen =>
{1}, {2, 2}, {3, 3, 3}, {4, 4, 4, 4}, {5, 5, 5, 5}, {6, 6, 6}, {7, 7}, {8}
Beispiel 2:
matrix = { {1, 2}, {2, 2} }
Lösung: falsch, denn die zweite Diagonale enthält unterschiedliche Zahlen =>
{1}, {1, 2}, {2}
Erstelle eine Methode/Funktion, die jede Matrix größer 2x2 dahingehend prüft, ob es sich um eine Toeplitz-Matrix handelt.
Viel Spaß
Beispiel 1:
matrix = { {4, 5, 6, 7, 8}, {3, 4, 5, 6, 7 }, {2, 3, 4, 5, 6}, {1, 2, 3, 4, 5} }
Lösung: wahr, denn alle Diagonalen enthalten die gleichen Zahlen =>
{1}, {2, 2}, {3, 3, 3}, {4, 4, 4, 4}, {5, 5, 5, 5}, {6, 6, 6}, {7, 7}, {8}
Beispiel 2:
matrix = { {1, 2}, {2, 2} }
Lösung: falsch, denn die zweite Diagonale enthält unterschiedliche Zahlen =>
{1}, {1, 2}, {2}
Erstelle eine Methode/Funktion, die jede Matrix größer 2x2 dahingehend prüft, ob es sich um eine Toeplitz-Matrix handelt.
Viel Spaß
#1

von AlexGroeg (2010 Punkte)
- 17.04.2021 um 17:08 Uhr

def ist_toeplitz_matrix(m): zeilen = len(m)-1 spalten = len(m[0])-1 n = zeilen * spalten if n < 1: print('Das ist keine Matrix !!') return False spalte = 0 while n > 0: for zeile in range(zeilen): try: if m[zeile][spalte] == m[zeile +1][spalte +1]: spalte += 1 else: return False except: spalte = 0 n -= 1 return True matrix = [ [4, 5, 6, 7, 8], [3, 4, 5, 6, 7], [2, 3, 4, 5, 6], [1, 2, 3, 4, 5] ] for i in matrix: print(i) print('Ist Toeplitz-Matrix:', ist_toeplitz_matrix(matrix), '\n') matrix = [ [1, 2], [2, 2] ] for i in matrix: print(i) print('Ist Toeplitz Matrix:', ist_toeplitz_matrix(matrix), '\n')
Kommentare:
Für diese Lösung gibt es noch keinen Kommentar
Seite 1 von 0
1