Das Ziel dieser Herausforderung ist es, ein Programm zu erstellen, das eine Matrix aufnimmt und seine reduzierte Zeilenebenenform ausgibt.
Eine Matrix liegt in reduzierter Reihenebenenform vor, wenn sie alle folgenden Bedingungen erfüllt:
- Wenn es eine Zeile gibt, in der jeder Eintrag Null ist, liegt diese Zeile unter jeder anderen Zeile, die einen Eintrag ungleich Null enthält.
- Der Eintrag ganz links ungleich Null einer Zeile ist gleich
1
.- Der Eintrag ganz links ungleich Null einer Zeile ist der einzige Eintrag ungleich Null in seiner Spalte.
- Betrachten Sie zwei verschiedene Einträge ganz links ungleich Null, einen in Zeile i, Spalte j und einen in Zeile s, Spalte t. Wenn ja
s>i
, dannt>j
.
Der allgemeine Prozess zum Transformieren der Matrix ist:
- Behandeln Sie jede Zeile i nacheinander von 1 bis n und arbeiten Sie über die Spalten j von 1 bis m, wobei Sie jede Spalte aller Null-Einträge überspringen.
- Suchen Sie die nächste Spalte j mit einem Eintrag ungleich Null.
- Tauschen Sie ggf. Zeilen aus, damit das Pivot-Element A (i, j) ungleich Null ist.
- Machen Sie den Pivot gleich 1, indem Sie jedes Element in der Pivot-Reihe durch den Wert des Pivots dividieren.
- Machen Sie alle Elemente über und unter dem Pivot gleich 0, indem Sie ein geeignetes Vielfaches der Pivot-Reihe von jeder anderen Reihe subtrahieren.
- Wiederholen Sie dies für alle Zeilen.
Wenn Sie mehr über diesen Matrixtyp erfahren möchten, lesen Sie den Wikipedia- Artikel und ein Tool und einen Artikel (Schritte oben) , in denen die Schritte zum Transformieren der Matrix aufgeführt sind.
Die eigentliche Herausforderung lautet:
Die Eingabe kann auf beliebige Weise über STDIN oder ein gleichwertiges Verfahren erfolgen. Bitte erläutern Sie dies in Ihrer Antwort. Die Ausgabe ist die reduzierte Zeilenebenenform der Eingabe in derselben Form wie die Eingabe über STDOUT oder eine gleichwertige Form. Standard Lücken sind nicht erlaubt und externe Bibliotheken oder Funktionen , die diese Aufgabe übernehmen sind ebenfalls nicht erlaubt ( TI-BASIC
‚s - rref(
Befehl, zum Beispiel). Sie können ein vollständiges Programm oder eine vollständige Funktion schreiben. Dies ist Code Golf, niedrigste BYTES gewinnt. Viel Glück!
Beispiel Eingabe: [[2,1,1,14][-1,-3,2,-2][4,-6,3,-5]]
Beispielausgabe: [[1,0,0,1][0,1,0,5][0,0,1,7]]
quelle
method(ref(matrix))
, würde ich sagen,Antworten:
R 232 Bytes
Dies ist nur eine Implementierung des üblichen Gaußschen Eliminierungsalgorithmus.
Ungolfed:
quelle
M[c(i,r),]=M[c(r,i),]
eher mit alst=M[i,];M[i,]=M[r,];M[r,]=t