• 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

    最终AC代码:

    #include <cstdio>
    #include <cstring>
    int main(){
        bool flag;
        int i, j, n, m, cnt;
        double sum, a[7], b[7][52]; //a[]存储课程平均分 b[][]存学生成绩 
        while(scanf("%d %d", &n, &m) != EOF){
            if(n==0 || m==0) break;
            memset(a, 0, sizeof(a));
            memset(b, 0, sizeof(b));
            for(i=0; i<n; i++){
                for(j=0; j<m; j++){
                    scanf("%lf", &b[i][j]);
                    a[j] += b[i][j];
                }
            }
            for(i=0; i<m; i++) a[i] /= n; //课程平均成绩 
            cnt = 0;
            for(i=0; i<n; i++){
                if(i > 0) printf(" ");
                sum = 0;
                flag = true;
                for(j=0; j<m; j++){
                    sum += b[i][j];
                    if(a[j]-b[i][j]>1e-6) flag = false;
                }
                if(flag) cnt++;
                printf("%.2lf", sum/m);
            }
            printf("
    ");
            for(i=0; i<m; i++){
                if(i > 0) printf(" ");
                printf("%.2lf", a[i]);
            }
            printf("
    %d
    
    ", cnt); //题目说的是这里空一行!!! 
        }
        return 0;
    }

    这题做的比较恶心,最开始错了两个地方,总结如下:

    一是对下面一段话的理解:

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

    这里,我错当成一共有m行,n列输入的情形处理了。只怪自己没认真审题!

    二是,对于下面一句话的理解:

    每个测试实例后面跟一个空行。

    嗯,我是以为每个输入的测试用例后面空一个空行!然后,OJ一直给我提示运行时错误~~~~但是,现在自己再想想,这句话是出现在Output中的格式要求,自然也是告诉我输出的格式应该是这样的!嗯,这么仔细一琢磨,倒不能怪题恶心,自己真的智商不在线啊!!!

    仅留下此篇当做教训吧!

  • 相关阅读:
    HDU-5818-Joint Stacks
    蓝桥杯-2016CC-卡片换位
    HDU-2255-奔小康赚大钱(KM算法)
    蓝桥杯-PREV31-小朋友排队
    crypto.js加密传输
    js之对象
    LigerUi之ligerMenu 右键菜单
    关于js中window.location.href,location.href,parent.location.href,top.location.href的用法
    设置js的ctx
    AngularJS简单例子
  • 原文地址:https://www.cnblogs.com/heyour/p/12554660.html
Copyright © 2020-2023  润新知