题解 | #成绩排序#

成绩排序

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;
}

全部评论

相关推荐

牛客41406533...:回答他在课上学,一辈子待在学校的老教授用三十年前的祖传PPT一字一句的讲解,使用谭浩强红皮书作为教材在devc++里面敲出a+++++a的瞬间爆出114514个编译错误来学这样才显得专业
点赞 评论 收藏
分享
陌夏微秋:一线城市25w左右吧,17×15=255
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务