期中考试结束了,老师已经批改完试卷了,但老师实在太忙了,想要写一个程序将所有学生的成绩信息处理一下,要求按照成绩的高低顺序输出各个学生的信息。
输入格式:
第一行输入一个n,代表有n个学生。接下来有n行,每一行中给出一名学生的学号num,姓名name,成绩score。学生人数0<n<=1000,学号为11位整型,保证学号各不相同,姓名为长度不超过20字符串,成绩为浮点型(0<score<=100.0)。
输出格式:
按照成绩降序输出n行,每一行中以一个空格隔开输出这个学生的学号、姓名、成绩,成绩保留两位小数,若有若干个学生的成绩相同,在保证成绩降序的前提下,按照学号的升序输出这些学生的信息。
请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。
输入样例:
3
17031310135 hwf 85.5
16031310135 hww 98
15031310135 hff 78.5
输出样例:
16031310135 hww 98.00
17031310135 hwf 85.50
15031310135 hff 78.50
#include<iostream> #include<cstdio> #include<cstring> using namespace std; struct node { char u[1010],v[101]; double w; } a[1010]; int main() { int n; while(cin>>n) { for(int i=0; i<n; i++) cin>>a[i].u>>a[i].v>>a[i].w; for(int i=0; i<n-1; i++) for(int j=i+1; j<n; j++) { if(a[i].w<a[j].w) { node b=a[i]; a[i]=a[j]; a[j]=b; } else if(a[i].w==a[j].w) { if(strcmp(a[i].u,a[j].u)>0) { node b=a[i]; a[i]=a[j]; a[j]=b; } } } for(int i=0; i<n; i++) printf("%s %s %.2lf\n",a[i].u,a[i].v,a[i].w); } return 0; }