题解 | #成绩排序#

成绩排序

https://www.nowcoder.com/practice/3f27a0a5a59643a8abf0140b9a8cf1f7

#include<stdio.h>
#include<stdlib.h>

typedef struct Student{
    int no;
    int score;
}Student;

int Compare(const void *a,const void *b){
    if(((Student*)a)->score==((Student*)b)->score)
        return ((Student*)a)->no-((Student*)b)->no;
    else
        return ((Student*)a)->score-((Student*)b)->score;
}

int main() {
    int n;
    while (scanf("%d",&n)!=EOF) { // 注意 while 处理多个 case
       Student s[n];
       for(int i=0;i<n;i++){
            scanf("%d%d",&s[i].no,&s[i].score);
       }
       qsort(s,n,sizeof(s[0]),Compare);
       for(int i=0;i<n;i++){
            printf("%d %d\n",s[i].no,s[i].score);
       }
    }
    return 0;
}

全部评论

相关推荐

2024-11-21 14:22
门头沟学院 硬件开发
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务