鱼C论坛

 找回密码
 立即注册
查看: 1295|回复: 0

[技术交流] qsort的比较函数以及用qsort对结构体排序

[复制链接]
发表于 2020-2-27 14:15:40 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
将学生数据按成绩从低到高排序,如果成绩相同则按姓名字符的字典序由小到大排序,如果姓名的字典序也相同则按照学生的年龄从小到大排序。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef struct Student
{
    char name[100];    //姓名
    int age;          //年龄
    int grade;         //分数
}student;

student stu[1000];

int cmp(const void* s1, const void* s2)//比较结构体成员的大小,s1和s2是指向数组元素的指针
{
    student *stu1 = (student *) s1;
    student *stu2 = (student *) s2;

    if(stu1 -> grade != stu2 -> grade)    //stu1是结构体指针,需要用->访问结构体成员
        return (stu1 -> grade - stu2 -> grade);
    else if(strcmp(stu1 -> name, stu2 -> name) != 0)
        return strcmp(stu1 -> name, stu2 -> name);
    else
        return (stu1 -> age - stu2 -> age);
}

int main()
{
    int n;                //一共n名学生
    int i;
    while(scanf("%d", &n) != EOF)
    {
        for(i = 0; i < n; i++)
        {
            scanf("%s %d %d", stu[i].name, &(stu[i].age), &(stu[i].grade));//stu[i]是结构体变量,要用.访问结构体成员
        }//输入信息
        qsort(stu, n, sizeof(stu[0]), cmp);        //排序
        for(i = 0; i < n; i++)
        {
            printf("%s %d %d\n", stu[i].name, stu[i].age, stu[i].grade);
        }
    }
    
    return 0;
}



想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-16 01:58

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表