qsort不排序和奇怪的输出
|
所以我在用C,我似乎无法正常工作。它是指向包含一些联系信息的结构的指针数组。我似乎无法让qsort正确排序。
这是我的代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX 20
#define ELEMENTS 50
int sortZips(const void *a, const void *b);
typedef struct contactInfo {
char name[MAX];
char street[MAX];
char cityState[MAX];
char zipCode[MAX];
} contacts;
int main() {
int i = 0;
contacts **contactArray = malloc(ELEMENTS * sizeof(contacts *));
/* allocate array */
for (i = 0; i < ELEMENTS; i++) {
contactArray[i] = malloc(sizeof(contacts));
}
/* populate array */
for (i = 0; i < ELEMENTS; i++) {
fgets(contactArray[i]->name,MAX,stdin);
fgets(contactArray[i]->street,MAX,stdin);
fgets(contactArray[i]->cityState,MAX,stdin);
fgets(contactArray[i]->zipCode,MAX,stdin);
printf(\"%s\", contactArray[i]->name);
printf(\"%s\", contactArray[i]->street);
printf(\"%s\", contactArray[i]->cityState);
printf(\"%s\", contactArray[i]->zipCode);
}
printf(\"\\n\");
/* qsort((void *)contactArray, ELEMENTS, sizeof(contacts *), sortZips); */
for (i = 0; i < ELEMENTS; i++) {
fputs(contactArray[i]->name,stdout);
fputs(contactArray[i]->street,stdout);
fputs(contactArray[i]->cityState,stdout);
fputs(contactArray[i]->zipCode,stdout);
}
}
/* sortZips() sort function for qsort */
int sortZips(const void *a, const void *b) {
const contacts *ia = *(contacts **)a;
const contacts *ib = *(contacts **)b;
return strcmp(ia->zipCode, ib->zipCode);
}
输出是打印地址(我在一个输入文件中有50个),然后打印一些随机字符,例如它们的一大块,然后是已排序的列表,其后的内容混乱不清。
请任何帮助将不胜感激。我需要了解这里的问题和原因。
谢谢
没有找到相关结果
已邀请:
3 个回复
磁辫覆氓
。如果不检查,您将不知道一切是否正常运行。 第二:一般优先使用
,而不是
。 检查早期EOF后,您的代码将我的样本数据(6行)整齐地排序了。它也可以干净地编译-这是非常不寻常的(这是一种赞美;我使用严格的警告,甚至我的代码也很少在第一次就干净地编译)。我修改后的代码版本与您的代码非常相似:
我使用的数据是4行的琐碎重复,如下所示:
请注意,我在输入中执行的“错误检查”是“工作”的最低要求。如果输入中有超长行,则一个字段将不包含换行符,而下一个字段将包含输入行的下一部分(可能是其余所有行,可能不是-这取决于行的加长程度) )。
耐钨徒
并且,当您执行
时,将仅读取
(19个字符,为空终止符留出空格)。 而且,关键是:文件指针仍将指向
位,因此,当您尝试读取
时,您会明白这一点。而且,当您尝试阅读
时,您会得到
行,有效地塞满了您的排序。
室邢
,它将为您清零内存。尽管更好的主意是使用一个计数器来实际读取多少个项目,而不是假设将有ELEMENTS个项目。