描述
某个班级有n位学生(n不超过100)和m门功课(m不超过20)。现在输入每个学生的姓名和每门功课成绩。要求计算每个同学的总分,按总分排序(降序)。 姓名最长不超20个字符。
输入
第一行输入两个整数,表示行数(n)和列数(m)。 接着n行,每行先输入姓名(姓名没有空格),然后输入m个整数,用空格分隔。每行代表一个同学的m门功课的分数
输出
输出排序后的全部同学,每行一个。输出他的姓名,每门课成绩和总分。用一个空格分隔。
样例
输入
7 3
Jack 91 75 99
Allan 90 88 95
Tom 87 97 67
Deng 76 48 43
Jane 65 76 67
Ana 94 85 87
Anne 83 92 89
输出
Allan 90 88 95 273
Ana 94 85 87 266
Jack 91 75 99 265
Anne 83 92 89 264
Tom 87 97 67 251
Jane 65 76 67 208
Deng 76 48 43 167
#include<stdio.h>
struct stud
{
char name[20];
int mark[20];
int total;
};
int main( )
{
struct stud a[100];
int n,m,i,j,k;
struct stud temp;
scanf("%d %d",&n,&m);
for(i=0;i<n;i++)
{
a[i].total=0;
scanf("%s",a[i].name);
for(j=0;j<m;j++)
{
scanf("%d",&a[i].mark[j]);
a[i].total+=a[i].mark[j];
}
}
for(i=1;i<n;i++)
for(j=0;j<n-i;j++)
if(a[j].total<a[j+1].total)
{
temp=a[j];a[j]=a[j+1];a[j+1]=temp;
}
for(i=0;i<n;i++)
{
printf("%s ",a[i].name);
for(j=0;j<m;j++)
printf("%d ",a[i].mark[j] );
printf("%d\n",a[i].total);
}
return 0;
}