c - 对结构体 C 的数组进行排序

标签 c arrays struct binaryfiles bubble-sort

我试图按名称对在二进制文件中读取的结构数组进行排序,但它无法编译, 这是我所做的:

struct candidate{
    char inscr[10];
    char name[44];
    int year;
    int position;
    char curse[30];
};
typedef struct candidate Candidate;



Candidate *read_sample_data(const char *filename) {
    FILE *fp = fopen(filename, "rb");

    if (fp == NULL)
    {
        fprintf(stderr, "Failed to open file %s for reading\n", filename);
        return 0;
    }
    fseek(fp, 0, SEEK_END);
    size_t sz = ftell(fp);
    rewind(fp);
    Candidate *aux=(Candidate*)(malloc(sizeof(Candidate)));
    Candidate  *arr = malloc(sz);
    if (arr == 0)
    {
        fprintf(stderr, "Failed to allocate %zu bytes memory\n", sz);
        return 0;
    }
    printf("%d",sz/sizeof(Candidate));
    int i;
    for (i = 0; fread(&arr[i], sizeof(Candidate), 1, fp) == 1; i++);
    for(i=sz-2;i>=0;i--){  //bubblesort
        int j =0;
        for(j = 0;j<=i;j++){
            if(strcmp( arr[j].inscr, arr[j+1].inscr ) > 0){
                aux=arr[j];
                arr[j]=arr[j+1];
                arr[j+1]=aux;
            }
        }
    }
}

我测试过,它从文件中读取我想要的内容,但我无法对其进行排序。 Ps.:我想对它进行排序,以便我可以将排序后的数组写入另一个二进制文件。

最佳答案

不确定如何编译代码(您是否忽略了所有警告?),但是这些行:

aux=arr[j];
arr[j] = arr[j+1];
arr[j+1] = aux;

应该是:

*aux=arr[j];
arr[j] = arr[j+1];
arr[j+1] = *aux;

关于c - 对结构体 C 的数组进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27117122/

相关文章:

c - 实现了名为 atof_beta 的 atof,但结果与 atof 不同

c++ - 是否可以将派生类数组截断为 C++ 中的基类数组?

c - 我如何在 CFFI 中包装包含结构指针的结构?

具有非连续布局的 C 位域元素

ios - 从函数返回 CGAffineTransform

c - IOCTL 调用无法读取和写入设备

c++ - 如何在C++中按字节写入文件

c - 在 C 中实现字符串的二叉搜索树

c - C 中返回结构体指针数组的函数签名的语法是什么?

arrays - 在 perl 中,检查数组中的值,如果另一个数组的每个值都存在则将其删除