Domanda
Ho bisogno di attuare qsort in C e ordinare in modo lessicografico inverso. Sono confuso su come creare e chiamare la funzione di confronto. Questo è ciò che ho finora ..
qsort (strArr, numLines, sizeof(char*) , sort);
int sort(const void * str1, const void * str2) {
return (-1) * strcasecmp((char*) str1, (char*) str2);
};
Eclipse mi sta dicendo " 'sort' sommerso (primo utilizzo in questa funzione)" sulla linea qsort, ma temo che non è il mio unico problema. Qualche consiglio?
Grazie, Hristo
Revisione ... questo è ciò che il mio allineamento appare come:
char **strArr = malloc(numLines * sizeof(char*));
fgets(output, 256, sourceFile);
strArr[i] = malloc(((int) strlen(output) + 1) * sizeof(char));
strcpy(strArr[i],output);
Soluzione
si avrebbe bisogno di dichiarare il tipo prima di usarlo:
int sort(const void * str1, const void * str2);
quindi il confronto potrebbe essere:
return strcasecmp(*(char * const *)str2, *(char * const *)str1);
Come @ Chris Jester-Young fa notare è possibile scambiare i args per invertire il confronto.
i puntatori devono essere dereferenziati ...
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow