按照结构体内部字段的值对数组进行排序
创始人
2024-08-24 09:30:07
0

以下是一个示例代码,展示了如何按照结构体内部字段的值对数组进行排序:

#include 
#include 

typedef struct {
    int value;
    char name[20];
} MyStruct;

// 比较函数,用于排序
int cmp(const void *a, const void *b) {
    MyStruct *structA = (MyStruct *)a;
    MyStruct *structB = (MyStruct *)b;
    return structA->value - structB->value;
}

int main() {
    MyStruct array[] = {
        {5, "John"},
        {2, "Peter"},
        {8, "Mary"},
        {3, "David"},
    };

    int arrayLength = sizeof(array) / sizeof(array[0]);

    // 使用qsort函数对数组进行排序
    qsort(array, arrayLength, sizeof(MyStruct), cmp);

    // 打印排序后的数组
    for (int i = 0; i < arrayLength; i++) {
        printf("%d: %s\n", array[i].value, array[i].name);
    }

    return 0;
}

在上面的示例中,我们首先定义了一个结构体 MyStruct,该结构体包含一个整数字段 value 和一个字符串字段 name

然后,我们定义了一个比较函数 cmp,该函数用于比较两个结构体的 value 字段的值。比较函数的返回值根据排序顺序而定,如果 a 应该排在 b 之前,则返回一个负数;如果 ab 相等,则返回0;如果 a 应该排在 b 之后,则返回一个正数。

接下来,我们在 main 函数中定义了一个包含多个结构体的数组 array,并计算了数组的长度。

最后,我们使用 qsort 函数对数组进行排序,传入数组的起始地址、数组的长度、每个元素的大小以及比较函数。

最终,我们打印排序后的数组,可以看到数组已按照结构体内部字段 value 的值进行了排序。

请注意,此示例仅用于演示目的,实际应用中可能需要根据实际情况进行适当修改。

相关内容

热门资讯

6分钟辅助!hhpoker是真... 6分钟辅助!hhpoker是真的假的,hhpoker真的有透视吗,演示教程(真是有挂)1、每一步都需...
第七分钟辅助!we poker... 第七分钟辅助!we poker插件,we poker免费辅助器,手筋教程(有挂方式)暗藏猫腻,小编详...
七分钟辅助!aa poker辅... 七分钟辅助!aa poker辅助包,pokemmo脚本辅助器下载,讲义教程(有挂秘籍)1、pokem...
第四分钟辅助!wepoker辅... 第四分钟辅助!wepoker辅助器安装包定制,aapoker透视脚本,大纲教程(有挂总结)所有人都在...
第四分钟辅助!wpk透视辅助靠... 第四分钟辅助!wpk透视辅助靠谱吗,wepoker透视苹果系统,诀窍教程(有挂猫腻);运wepoke...
七分钟辅助!aapoker透视... 七分钟辅助!aapoker透视脚本入口,wejoker开挂,学习教程(有挂教程)1、打开软件启动之后...
第四分钟辅助!淘宝买wepok... 第四分钟辅助!淘宝买wepoker透视有用吗,wpk俱乐部怎么作弊,积累教程(有挂规律)1、下载好淘...
6分钟辅助!we-poker软... 6分钟辅助!we-poker软件,购买的wpk辅助在哪里下载,积累教程(有挂技巧)购买的wpk辅助在...
第2分钟辅助!如何下载wepo... 第2分钟辅助!如何下载wepoker安装包,newpoker怎么安装脚本,教程书教程(今日头条)1、...
4分钟辅助!wepoker钻石... 4分钟辅助!wepoker钻石怎么看底牌,wepoker辅助器有哪些功能,法门教程(有挂详细)该软件...