VJ,OJ求平均成绩

    技术2022-07-10  184

    假设一个班有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

    ```c # include<stdio.h> #include<string.h> int main() { double temp, a[60][20], crosssum, rowsum, b[10], individual_average; int i, j, qualified_count, n, m; while(scanf("%d%d", &n, &m) != EOF) { qualified_count = 0; for(i = 0; i < n; i++ ) for(j = 0; j < m; j++) scanf("%lf", &a[i][j]); //getchar(); //getchar(); crosssum = 0; rowsum = 0; for(i = 0; i < n; i++ ) { crosssum = 0; for(j = 0; j < m; j++) crosssum += a[i][j]; individual_average = crosssum / m; if(i == n - 1) printf("%.2lf\n", individual_average); else printf("%.2lf ", individual_average); } for(j = 0; j < m; j++ ) { rowsum = 0; for(i = 0; i < n; i++) rowsum += a[i][j]; b[j] = rowsum / n;; if(j == m - 1) printf("%.2lf\n", b[j]); else printf("%.2lf ", b[j]); } //qualified_count = 0; for(i = 0; i < n; i++ ) { for(j = 0; j < m; j++) if(a[i][j] >= b[j]) continue; else break; if(j == m) qualified_count++; } printf("%d\n\n", qualified_count);//还好吧,题目说了每个测试实例后跟一个空行,我没有注意到。我理解成了每个测试实例的第一行后面面要跟一个空格。 } return 0; }
    Processed: 0.009, SQL: 9