Ich habe den folgenden Code geschrieben sortierten Ketten in einem 2-D-Zeichen-ArrayZeichenfeld in der Luftblase Art
#include <stdio.h>
#include <string.h>
void swap(char *,char *);
void main() {
char a[20][20];
int Pass = 0, i = 0, j = 0, n;
printf("\nHow many elements you want to sort ? >> ");
scanf("%d", &n);
printf("\n\nEnter the elements to be sorted :\n");
for (i = 0; i < n; i++)
scanf("%s", a[i]);
for (Pass = 1; Pass < n; Pass++) {
for (j = 0; j < n - Pass; j++)
if (strcmp(a[j], a[j + 1]) < 0)
swap(a[j], a[j + 1]);
printf("\n\nPass = %d\n", Pass);
for (i = 0; i < n; i++)
printf(" %s ", a[i]);
}
}
void swap(char *a, char *b) {
char *t;
*t = *a;
*a = *b;
*b = *t;
}
zu bekommen Aber ich Ausgabe als
How many elements you want to sort ? >> 5
Enter the elements to be sorted :
1 2 3 4 5
Pass = 1
2 3 4 5 1
Pass = 2
3 4 5 2 1
Pass = 3
4 5 3 2 1
Pass = 4
Segmentation fault (core dumped)
bekommen Warum ich Segmentierung Sie begegnen Fehler? (Der gleiche Code funktioniert einwandfrei, wenn I ein Integer-Array anstelle eines Zeichenfeldes)
Haupt zurückkehren muss 'int ' –
Ihre' swap' Funktion ist falsch. 1) 'char * t; * t = * a; ': Nicht initialisierte Variable verwenden. 2) Was ausgetauscht werden soll, ist ein Array und nicht ein Zeiger (oder ein "char"). – BLUEPIXY
Sparen Sie Zeit, aktivieren Sie alle Warnungen des Compilers: 'char * t; * t = * a; 'sollte warnen, dass' t' vor der Initialisierung verwendet wird. – chux