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);
È stato utile?

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
scroll top