Forum: Mikrocontroller und Digitale Elektronik String sortieren mit Qsort


von Hans W. (stampede)


Lesenswert?

Moin,

wie gesagt, es geht um Sortierung mit qsort.

Dazu habe ich erstmal ein Array erzeugt, und die Suchfunktion 
drüberlaufen lassen, das hat soweit auch funktioniert. Das Array soll 32 
Strings mit max. 256 Byte Länge enthalten.
Ich habe mal die Codeausschnitt mal auf die entscheidenden Teile 
reduziert.
1
FileList[32][256];
2
3
// Füllen mit Strings [...]
4
strcpy(FileList[i], finfo.lfname); 
5
6
qsort((void *)FileList, TotalFileCount, sizeof(fileListString), compare);  // Sort the array
7
8
int  compare(const void *a, const void *b)
9
{
10
    const char *ia = (const char *)a;
11
    const char *ib = (const char *)b;
12
    return strcmp(ia, ib);
13
}

Das klappt soweit auch. Da das Array aber recht dünn besetzt ist, wollte 
ich die Speicherverschwendung vermeiden und allokiere nun den Speicher 
dynamisch:
1
WORD MallocIndex;
2
FileList = malloc(TotalFileCount * sizeof(char *));  
3
MallocIndex = 0;
4
5
// Array füllen [..]
6
FileList[MallocIndex] = malloc(strlen(finfo.lfname) + 1);
7
strcpy(FileList[MallocIndex], finfo.lfname);
Soweit so gut, die Elemente landen im Array und ich kann sie ausgeben.

Nun würde ich diese Strings gerne sortieren. Dafür habe ich erst mal die 
compare Funktion angepasst:
1
int  compare(const void *a, const void *b)
2
{
3
    const char *ia = (const char **)a;
4
    const char *ib = (const char **)b;
5
    return strcmp(ia, ib);
6
}

Jetzt muss ich noch das qsort richtig aufrufen, und das klappt nicht so 
recht.
Ich muss ja die Pointer vertauschen, und nicht wie vorher die Strings 
selber. Wie mache ich das also mit dynamischer Speicherverwaltung?
1
qsort((void *)FileList, TotalFileCount, sizeof(fileListString), compare);  // GEHT SO LOGISCHERWEISE NICHT

Gruß

von Hans W. (stampede)


Lesenswert?

Got it:

Der Aufruf muss so lauten:
qsort(FileList, TotalFileCount, sizeof(char *), compare);        // Sort

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.