有5名学生保存在结构体数组中,编程按学生的成绩升序排序,按学生的姓名降序排序,按年龄从低到高排序

#import <Foundation/Foundation.h>

typedef struct Data{

    int year;//存储年份

    int month;//存储月份

    int day;//存储天


}data;

void printAllStuInfo( Stu a[], int count){

    for (int i = 0; i < count; i++) {

        printf("name=%s ",a[i].name);

        printf("age=%d ",a[i].age);

        printf("score=%.2f",a[i].score);

        printf("\n");

    }

}

//编程按学生的成绩升序排序,

void sortOfScore(Stu a[],int count){

    for (int i =0; i < count -1;i++) {

        for (int j =0; j < count -1 -i; j++) {

            if (a[j].score > a[j+1].score) {

                Stu temp = a[j];

                a[j] = a[j+1];

                a[j+1]= temp;

            }

        }

    }

}

//按学生的姓名降序排序,

void sortOfName(Stu a[],int count){

    for (int i =0; i < count -1;i++) {

        for (int j =0; j < count -1 -i; j++) {

            if (strcmp(a[j].name, a[j+1].name) > 0) {

                Stu temp = a[j];

                a[j] = a[j+1];

                a[j+1]= temp;

            }


        }

    }

}

//按年龄从低到高排序

void sortOfAge(Stu a[],int count){

    for (int i =0; i < count -1;i++) {

        for (int j =0; j < count -1 -i; j++) {

            if (a[j].age > a[j+1].age) {

                Stu temp = a[j];

                a[j] = a[j+1];

                a[j+1]= temp;

            }


        }

    }

}

int main(int argc, const char * argv[])

{

    Stu student[5] = {

        {"zhangsan",23,88},

        {"lisi",21,86},

        {"wangwu",18,99},

        {"zhaoliu",22,66},

        {"qianqi",18,77}

    };


printf("排序前\n");

     printAllStuInfo(student,5);

    //编程按学生的成绩升序排序,

    printf("\n按成绩排序\n");

    sortOfScore(student,5);

    printAllStuInfo(student,5);

    //按学生的姓名降序排序,

    printf("按姓名排序\n");

     sortOfName(student,5);

    printAllStuInfo(student,5);

    //按年龄从低到高排序

    printf("按年龄排序\n");

     sortOfAge(student,5);

    printAllStuInfo(student,5);

 return 0;

}



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值