题目来源:http://pat.zju.edu.cn/contests/pat-b-practise/1004
教训:别傻帽似的认为题目要求字符串个数不超过10,就呆呆的把数组开为10.。多开点,也没叫你要钱。。主要是你输入一串字符串,结尾还有个回车呢。。所以以后,数组尽量开大点。
#include<stdio.h>
#include<stdlib.h>
typedef struct{
char name[15];
char sno[15];
int grade;
}student;
student stu[10000];
int cmp(const void*a,const void*b)
{return (*(student *)a).grade<(*(student *)b).grade?1:-1;
}
int main()
{int n;
scanf("%d",&n);
int i;
for(i=0;i<n;i++)
{scanf("%s %s %d",stu[i].name,stu[i].sno,&stu[i].grade);
}
qsort(stu,n,sizeof(student),cmp);
printf("%s %s\n",stu[0].name,stu[0].sno);
printf("%s %s\n",stu[n-1].name,stu[n-1].sno);
return 0;
}