Heim >Backend-Entwicklung >C++ >C-Programm zum Sortieren aller Spalten und Zeilen einer Matrix
Schreiben Sie Code, um alle Zeilen einer Matrix in aufsteigender Reihenfolge und alle Spalten in absteigender Reihenfolge zu sortieren. Die Größe und Elemente der Matrix werden vom Benutzer zur Laufzeit bereitgestellt.
Lösung zum Sortieren aller Zeilen einer Matrix in aufsteigender Reihenfolge und aller Spalten in absteigender Reihenfolge in der Programmiersprache C wird unten erklärt:
Die zum Sortieren der Zeilen in aufsteigender Reihenfolge verwendete Logik lautet wie folgt:
for (i=0;i<m;++i){ for (j=0;j<n;++j){ for (k=(j+1);k<n;++k){ if (ma[i][j] > ma[i][k]){ a = ma[i][j]; ma[i][j] = ma[i][k]; ma[i][k] = a; } } } }
Für Sortieren nach Die Logik zum Sortieren von Spalten in absteigender Reihenfolge lautet wie folgt: −
for (j=0;j<n;++j){ for (i=0;i<m;++i){ for (k=i+1;k<m;++k){ if (mb[i][j] < mb[k][j]){ a = mb[i][j]; mb[i][j] = mb[k][j]; mb[k][j] = a; } } } }
Das Folgende ist ein C-Programmzum Sortieren aller Zeilen einer Matrix in aufsteigender Reihenfolge und aller Spalten in absteigender Reihenfolge −
Echtzeit Demonstration
#include <stdio.h> void main(){ int i,j,k,a,m,n; static int ma[10][10],mb[10][10]; printf ("Enter the order of the matrix </p><p>"); scanf ("%d %d", &m,&n); printf ("Enter co-efficients of the matrix </p><p>"); for (i=0;i<m;++i){ for (j=0;j<n;++j){ scanf ("%d",&ma[i][j]); mb[i][j] = ma[i][j]; } } printf ("The given matrix is </p><p>"); for (i=0;i<m;++i){ for (j=0;j<n;++j){ printf (" %d",ma[i][j]); } printf ("</p><p>"); } printf ("After arranging rows in ascending order</p><p>"); for (i=0;i<m;++i){ for (j=0;j<n;++j){ for (k=(j+1);k<n;++k){ if (ma[i][j] > ma[i][k]){ a = ma[i][j]; ma[i][j] = ma[i][k]; ma[i][k] = a; } } } } for (i=0;i<m;++i){ for (j=0;j<n;++j){ printf (" %d",ma[i][j]); } printf ("</p><p>"); } printf ("After arranging the columns in descending order </p><p>"); for (j=0;j<n;++j){ for (i=0;i<m;++i){ for (k=i+1;k<m;++k){ if (mb[i][j] < mb[k][j]){ a = mb[i][j]; mb[i][j] = mb[k][j]; mb[k][j] = a; } } } } for (i=0;i<m;++i){ for (j=0;j<n;++j){ printf (" %d",mb[i][j]); } printf ("</p><p>"); } }
Wenn das oben genannte Programm ausgeführt wird, erzeugt es das folgende Ergebnis: −
Enter the order of the matrix 3 4 Enter co-efficient of the matrix 1 2 3 4 1 2 3 4 5 1 2 3 The given matrix is 1 2 3 4 1 2 3 4 5 1 2 3 After arranging rows in ascending order 1 2 3 4 1 2 3 4 1 2 3 5 After arranging the columns in descending order 5 2 3 4 1 2 3 4 1 1 2 3
Das obige ist der detaillierte Inhalt vonC-Programm zum Sortieren aller Spalten und Zeilen einer Matrix. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!