Schreiben Sie ein Programm, um ein eindimensionales Array von N Elementen zu nehmen und es in zwei Hälften zu teilen. Sortieren Sie später die erste Hälfte in aufsteigender Reihenfolge und die zweite Hälfte in absteigender Reihenfolge.
Die Lösung zum Durchführen von zwei Operationen an zwei Hälften in einem einzelnen Array wird in C-Sprache wie folgt erklärt:
Die Logik zum Sortieren der ersten Hälfte in aufsteigender Reihenfolge lautet wie folgt -
for (i=0; i<b; ++i){ for (j=i+1; j<b; ++j){ if (number[i] > number[j]){ a = number[i]; number[i] = number[j]; number[j] = a; } } }
zum Sortieren der zweiten Hälfte in absteigender Reihenfolge Die Logik von ist wie folgt –
for (i=b; i<n; ++i){ for (j=i+1; j<n; ++j){ if (number[i] < number[j]){ a = number[i]; number[i] = number[j]; number[j] = a; } } }
Die Logik, die verwendet wird, um das Array in zwei Hälften aufzuteilen und entsprechend zu drucken, ist wie folgt –
for (i=0; i<b; ++i) printf ("%d ",number[i]);
for(i=b;i<n;i++) printf("%d ",number[i]);
Das Folgende ist für ein einzelnes Array. Zwei Hälften eines C-Programms, das zwei Operationen ausführt –
Live-Demonstration
#include<stdio.h> void main(){ int i,j,a,n,b,number[30]; printf ("Enter the value of N</p><p>"); scanf ("%d", &n); b = n/2; printf ("Enter the numbers </p><p>"); for (i=0; i<n; ++i) scanf ("%d",&number[i]); for (i=0; i<b; ++i){ for (j=i+1; j<b; ++j){ if (number[i] > number[j]){ a = number[i]; number[i] = number[j]; number[j] = a; } } } for (i=b; i<n; ++i){ for (j=i+1; j<n; ++j){ if (number[i] < number[j]){ a = number[i]; number[i] = number[j]; number[j] = a; } } } printf (" The 1st half numbers</p><p>"); printf (" arranged in asc</p><p>"); for (i=0; i<b; ++i) printf ("%d ",number[i]); printf("</p><p>The 2nd half Numbers</p><p>"); printf("order arranged in desc.order</p><p>"); for(i=b;i<n;i++) printf("%d ",number[i]); }
Wenn das obige Programm ausgeführt wird, werden die folgenden Ergebnisse erzeugt –
Enter the value of N 10 Enter the numbers 20 34 23 11 45 56 78 98 76 54 The 1st half numbers arranged in asc 11 20 23 34 45 The 2nd half Numbers order arranged in desc.order 98 78 76 56 54
Das obige ist der detaillierte Inhalt vonC-Programm zum Ausführen zweier Hälften einer Operation auf einem einzelnen Array. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!