题目描述
有N个学生的数据,将学生数据按成绩从低到高排序,如果成绩相同则按姓名字符的字典序由小到大排序,如果姓名的字典序也相同则按照学生的年龄从小到大排序,并输出N个学生排序后的信息。
输入描述:
测试数据有多组,每组输入第一行有一个整数N(N<=1000),接下来的N行包括N个学生的数据。 每个学生的数据包括姓名(长度不超过100的字符串)、年龄(整形数)、成绩(小于等于100的正数)。
输出描述:
将学生信息按成绩进行排序,成绩相同的则按姓名的字母序进行排序。 然后输出学生信息,按照如下格式: 姓名 年龄 成绩 学生姓名的字母序区分字母的大小写,如A要比a的字母序靠前(因为A的ASC码比a的ASC码要小)。
示例1
输入
复制
3 abc 20 99 bcd 19 97 bed 20 97
输出
复制
bcd 19 97 bed 20 97 abc 20 99
#include <stdio.h>
#include <string.h>
typedef struct student{
char name[100];
int age;
int score;
}stu;
int cmp(const void*a,const void*b){
stu *a1=(stu*)a;
stu *b1=(stu*)b;
if(a1->score!=b1->score)
return a1->score-b1->score;
else if(strcmp(a1->name,b1->name)!=0)
return strcmp(a1->name,b1->name);
else
return a1->age-b1->age;
}
int main(){
int n;
while(scanf("%d",&n)!=EOF){
stu a[n];
for(int i=0;i<n;i++){
scanf("%s%d%d",&a[i].name,&a[i].age,&a[i].score);
}
qsort(a,n,sizeof(stu),cmp);
for(int i=0;i<n;i++){
printf("%s %d %d\n",a[i].name,a[i].age,a[i].score);
}
}
return 0;
}