来自远古的声音 2022-04-06 22:33 采纳率: 80%
浏览 60
已结题

即:当 C=1 时,按学号递增排个测试用、中输出按要求排序后的结果,即:当 C=1 时,按学号递增排序;当 C=2时,按姓名的非递减字典序排序;当 C=3 时,按成绩

Description
给大家说过了会出这个原题。相信大家都已经准备好了,那就快完成签到吧
Input
测试输入包含若干测试用例。每个测试用例的第1行包含两个整数 N (<=100000) 和 C,其中 N 是纪录的条数,C 是指定排序的列号。以下有 N
行,每行包含一条学生纪录。每条学生纪录由学号(6位数字,同组测试中没有重复的学号)、姓名(不超过8位且不包含空格的字符串)、成绩(闭区间[0 100]内的整数)组成,每个项目间用1个空格隔开。当读到 N=0 时,全部输入结束,相应的结果不要输出。
Output
对每个测试用例,首先输出1行“Case i:”,其中 i 是测试用例的编号(从1开始)。随后在 N 行中输出按要求排序后的结果,即:当 C=1 时,按学号递增排序;当 C=2时,按姓名的非递减字典序排序;当 C=3时,按成绩的非递减排序。当若干学生具有相同姓名或者相同成绩时,则按他们的学号递增排序。对每个测试用例,首先输出1行“Case i:”,其中 i 是测试用例的编号(从1开始)。随后在 N 行中输出按要求排序后的结果,即:当 C=1 时,按学号递增排序;当 C=2时,按姓名的非递减字典序排序;当 C=3
时,按成绩的非递减排序。当若干学生具有相同姓名或者相同成绩时,则按他们的学号递增排序。
Sample Input
3 1
000007 James 85
000010 Amy 90
000001 Zoe 60
4 2
000007 James 85
000010 Amy 90
000001 Zoe 60
000002 James 98
4 3
000007 James 85
000010 Amy 90
000001 Zoe 60
000002 James 90
0 0
Sample Output
Case 1:
000001 Zoe 60
000007 James 85
000010 Amy 90
Case 2:
000010 Amy 90
000002 James 98
000007 James 85
000001 Zoe 60
Case 3:
000001 Zoe 60
000007 James 85
000002 James 90
000010 Amy 90

  • 写回答

1条回答 默认 最新

  • 来自远古的声音 2022-04-08 20:07
    关注

    #include<stdio.h>
    #include<string.h>
    #include //排序函数库
    using namespace std;
    struct student
    {
    char ID[7];
    char name[9];
    int score;
    }a[10000];
    bool xuehao(student a,student b)
    {
    return strcmp(a.ID,b.ID)<0;
    }
    bool xingming(student a,student b)
    {
    if(strcmp(a.name,b.name)==0)
    {
    return strcmp(a.ID,b.ID)<0;
    }
    else
    {
    return strcmp(a.name,b.name)<0;
    }
    }
    bool chengji(student a,student b)
    {
    if(a.score==b.score)
    {
    return strcmp(a.ID,b.ID)<0;
    }
    else
    {
    return a.score<b.score;
    }
    }
    int main()
    {
    int N=0,C=0;
    while(scanf("%d%d",&N,&C),N!=0)
    {
    for(int i=0;i<N;i++)
    {
    scanf("%s %s %d", a[i].ID, a[i].name, &a[i].score);
    }
    switch(C)
    {
    case (1):
    sort(a,a+N,xuehao);
    break;
    case (2):
    sort(a,a+N,xingming);
    break;
    case (3):
    sort(a,a+N,chengji);
    break;
    }
    printf("Case %d:\n",C);
    for(int i=0;i<N;i++)
    {
    printf("%s %s %d\n",a[i].ID,a[i].name,a[i].score);

        }
    

    }
    return 0;
    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 4月16日
  • 已采纳回答 4月8日
  • 创建了问题 4月6日

悬赏问题

  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改