hdoj 2023 求平均成绩【基础题】

来源:互联网 发布:有毒网络剧歌曲 编辑:程序博客网 时间:2024/05/07 08:11

求平均成绩

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


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
 代码:
#include<cstdio>#include<cstring>#include<cstdlib>#include<algorithm>using namespace std;int pp[110][110];double sum1[110],sum2[110];int main(){int n,m;while(scanf("%d%d",&n,&m)!=EOF){int cnt=0;memset(sum1,0,sizeof(sum1));memset(sum2,0,sizeof(sum2));for(int i=0;i<n;i++)  for(int j=0;j<m;j++)  {    scanf("%d",&pp[i][j]);    sum1[i]=sum1[i]+pp[i][j];    sum2[j]=sum2[j]+pp[i][j];      }      for(int i=0;i<n;i++)       {       sum1[i]/=m;       printf(i==n-1?"%.2lf\n":"%.2lf ",sum1[i]);       }       for(int i=0;i<m;i++)       {       sum2[i]/=n;       printf(i==m-1?"%.2lf\n":"%.2lf ",sum2[i]);       }       for(int k=0;k<n;k++)       {       bool flag=true;       for(int l=0;l<m;l++)       {       if(pp[k][l]<sum2[l])       {       flag=false;       break;       }       }       if(flag)       cnt++;       }       printf("%d\n\n",cnt);}return 0;} 

0 0
原创粉丝点击