HDU 2023 求平均成绩.

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
 
====
不解释了,直接上代码。

#include<stdio.h>
int main()
{
    int i,j,n,m,s[55][10];
    while(~scanf("%d%d",&n,&m))
    {
        double a[55]={0},b[10]={0},c[10];
        for(i=0;i<n;i++)
            for(j=0;j<m;j++)
            {
                scanf("%d",&s[i][j]);
                a[i]+=s[i][j];
            }

        for(j=0;j<m;j++)
            for(i=0;i<n;i++)
                b[j]+=s[i][j];

        for(i=0;i<n;i++)
            if(i==0) printf("%.2lf",a[i]/m);
            else printf(" %.2lf",a[i]/m);
        printf("\n");

        for(j=0;j<m;j++)
            if(j==0) printf("%.2lf",c[j]=b[j]/n);
            else printf(" %.2lf",c[j]=b[j]/n);
        printf("\n");

        int k=0;
        for(i=0;i<n;i++)
        {
            for(j=0;j<m;j++)
                if(s[i][j]<c[j]) break;
            if(j==m)
                k++;
        }
        printf("%d\n\n",k);
    }
    return 0;
}


HDU 2023 求平均成绩.

上一篇:UVa 11992 Fast Matrix Operations / 线段树成段更新


下一篇:Codeforces Beta Round #2 A B C