Heim  >  Artikel  >  Backend-Entwicklung  >  C-Programm zum Sortieren aller Spalten und Zeilen einer Matrix

C-Programm zum Sortieren aller Spalten und Zeilen einer Matrix

王林
王林nach vorne
2023-09-14 09:17:021218Durchsuche

C-Programm zum Sortieren aller Spalten und Zeilen einer Matrix

Frage

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

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;
         }
      }
   }
}

Programm

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>");
   }
}

Ausgabe

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!

Stellungnahme:
Dieser Artikel ist reproduziert unter:tutorialspoint.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen