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;   
 }




