ACM2023
添加时间:2013-6-19 点击量:
/
求均匀成绩
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 47739 Accepted Submission(s): 11343
Problem Description
假设一个班有n(n<=50)个学生,每人考m(m<=5)门课,求每个学生的均匀成绩和每门课的均匀成绩
,并输出各科成绩均大于便是均匀成绩的学生数量。
Input
输入数占领多个测试实例,每个测试实例的第一行包含两个整数n和m,分别默示学生数和课程数。
然后是n行数据,每行包含m个整数(即:测验分数)。
Output
对于每个测试实例,输出3行数据,第一行包含n个数据,默示n个学生的均匀成绩,成果保存两位
小数;第二行包含m个数据,默示m门课的均匀成绩,成果保存两位小数;第三行是一个整数,表
示该班级中各科成绩均大于便是均匀成绩的学生数量。
每个测试实例后面跟一个空行。
Sample Input
2 2
5 10
10 20
Sample Output
7.50 15.00
7.50 15.00
1
Author
lcy
/
#include <cstdio>
int main()
{
int n,m,score[50][5],num;
while(~scanf(%d%d,&n,&m))
{
double ans[2][50];
for(int i=0,sum=0;i<n;i++,sum=0)
{
for(int j=0;j<m;j++)
{
scanf(%d,&score[i][j]);
sum=sum+score[i][j];
}
ans[0][i]=(double)sum/m;//将均匀数放入ans[0][i]中
} //第0行动每个学生的均匀数
for(int i=0,sum=0;i<m;i++,sum=0)
{
for(int j=0;j<n;j++)
{
sum=sum+score[j][i];
}
ans[1][i]=(double)sum/n;
}//算每门课的均匀的成绩
num=0;
for(int i=0,flag=1;i<n;i++,flag=1)
{
for(int j=0;j<m;j++)
{
if(score[i][j]<ans[1][j])
{flag=0;break;}
}
if(flag)
num++;
}//查找各科成绩均大于均娄
for(int i=0;i<n;i++)
printf(i==n-1?%.2lf\n:%.2lf ,ans[0][i]);
for(int i=0;i<m;i++)
printf(i==m-1?%.2lf\n:%.2lf ,ans[1][i]);
printf(%d\n\n,num);
}
return 0;
}
彼此相爱,却不要让爱成了束缚:不如让它成为涌动的大海,两岸乃是你们的灵魂。互斟满杯,却不要同饮一杯。相赠面包,却不要共食一个。一起歌舞欢喜,却依然各自独立,相互交心,却不是让对方收藏。因为唯有生命之手,方能收容你们的心。站在一起却不要过于靠近。—— 纪伯伦《先知》
/
求均匀成绩
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 47739 Accepted Submission(s): 11343
Problem Description
假设一个班有n(n<=50)个学生,每人考m(m<=5)门课,求每个学生的均匀成绩和每门课的均匀成绩
,并输出各科成绩均大于便是均匀成绩的学生数量。
Input
输入数占领多个测试实例,每个测试实例的第一行包含两个整数n和m,分别默示学生数和课程数。
然后是n行数据,每行包含m个整数(即:测验分数)。
Output
对于每个测试实例,输出3行数据,第一行包含n个数据,默示n个学生的均匀成绩,成果保存两位
小数;第二行包含m个数据,默示m门课的均匀成绩,成果保存两位小数;第三行是一个整数,表
示该班级中各科成绩均大于便是均匀成绩的学生数量。
每个测试实例后面跟一个空行。
Sample Input
2 2
5 10
10 20
Sample Output
7.50 15.00
7.50 15.00
1
Author
lcy
/
#include <cstdio>
int main()
{
int n,m,score[50][5],num;
while(~scanf(%d%d,&n,&m))
{
double ans[2][50];
for(int i=0,sum=0;i<n;i++,sum=0)
{
for(int j=0;j<m;j++)
{
scanf(%d,&score[i][j]);
sum=sum+score[i][j];
}
ans[0][i]=(double)sum/m;//将均匀数放入ans[0][i]中
} //第0行动每个学生的均匀数
for(int i=0,sum=0;i<m;i++,sum=0)
{
for(int j=0;j<n;j++)
{
sum=sum+score[j][i];
}
ans[1][i]=(double)sum/n;
}//算每门课的均匀的成绩
num=0;
for(int i=0,flag=1;i<n;i++,flag=1)
{
for(int j=0;j<m;j++)
{
if(score[i][j]<ans[1][j])
{flag=0;break;}
}
if(flag)
num++;
}//查找各科成绩均大于均娄
for(int i=0;i<n;i++)
printf(i==n-1?%.2lf\n:%.2lf ,ans[0][i]);
for(int i=0;i<m;i++)
printf(i==m-1?%.2lf\n:%.2lf ,ans[1][i]);
printf(%d\n\n,num);
}
return 0;
}