hdu 2023 求平均成绩

来源:互联网 发布:linux新建文件命令 编辑:程序博客网 时间:2024/04/30 09:56

求平均成绩

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 49036    Accepted Submission(s): 11655

Problem Description
假设一个班有n(n<=50)个学生,每人考m(m<=5)门课,求每个学生的平均成绩和每门课的平均成绩,并输出各科成绩均大于等于平均成绩的学生数量。
 

Input
输入数据有多个测试实例,每个测试实例的第一行包括两个整数n和m,分别表示学生数和课程数。然后是n行数据,每行包括m个整数(即:考试分数)。
 

Output
对于每个测试实例,输出3行数据,第一行包含n个数据,表示n个学生的平均成绩,结果保留两位小数;第二行包含m个数据,表示m门课的平均成绩,结果保留两位小数;第三行是一个整数,表示该班级中各科成绩均大于等于平均成绩的学生数量。每个测试实例后面跟一个空行。
 

Sample Input
2 25 1010 20
 

Sample Output
7.50 15.007.50 15.001
 

Author
lcy
 

Source
C语言程序设计练习(四)
 

Recommend
lcy
 

水题一枚,但因忘记初始化,wa了若干次
#include <iostream>#include<cstdio>#include<cstring>using namespace std;int main(){    int a[60][10];    double sa[60],ca[10];    int sum;    int n,m;    int i,j;  while(~scanf("%d%d",&n,&m))  {       sum=0;     memset(sa,0,sizeof(sa));     memset(ca,0,sizeof(ca));    for(i=0;i<n;i++)     {         for(j=0;j<m;j++)       {           cin>>a[i][j];           sa[i]+=a[i][j];       }     sa[i]/=(double)m;     }    for(j=0;j<m;j++)    {        for(i=0;i<n;i++)      {        ca[j]+=a[i][j];     }    ca[j]/=(double)n;    }    int f=0;  for(i=0;i<n;i++)  {   f=0;      for(j=0;j<m;j++)       if(a[i][j]<ca[j]) {f=1;break;}     if(f==0) sum++;  } for(i=0;i<n-1;i++)    printf("%.2lf ",sa[i]);     printf("%.2lf\n",sa[n-1]); for(i=0;i<m-1;i++)   printf("%.2lf ",ca[i]);  printf("%.2lf\n",ca[m-1]);  cout<<sum<<endl;  cout<<endl;  }    return 0;}

原创粉丝点击