HDOJ 2023 求平均成绩

举报
谙忆 发表于 2021/05/27 18:18:15 2021/05/27
【摘要】 Problem Description 假设一个班有n(n<=50)个学生,每人考m(m<=5)门课,求每个学生的平均成绩和每门课的平均成绩,并输出各科成绩均大于等于平均成绩的学生数量。 Input 输入数据有多个测试实例,每个测试实例的第一行包括两个整数n和m,分别表示学生数和课程数。然后是n行数据,每行包括m个整数(即:考试分数)。 Output 对于每个...

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

在此,我利用的方法是,如果是n*m的大小,我就开(n+1)*(m+1)
大小的空间,最后一行的数据用来存放当前一行的数据和,最后一列的数据用来
存放当前一列的数据之和。

import java.util.Scanner;
class Main{ public static void main(String args[]){ Scanner sc =new  Scanner(System.in); while(sc.hasNext()){ int n =sc.nextInt(); int m =sc.nextInt(); int stuStr[][] = new int[n+1][m+1]; for(int i=0;i<n;i++){ for(int j=0;j<m;j++){ stuStr[i][j] = sc.nextInt(); stuStr[i][m] = stuStr[i][j]+stuStr[i][m];//一门课的n个学生的平均成绩 stuStr[n][j] = stuStr[i][j]+stuStr[n][j];//一个学生m门课的平均成绩 } } double nStr[] = new double[n]; double mStr[] = new double[m]; nStr[0] =(double)stuStr[0][m]/m; System.out.printf("%.2f",nStr[0]); for(int i=1;i<n;i++){ nStr[i] = (double)stuStr[i][m]/m; System.out.printf(" %.2f",nStr[i]); } System.out.println(); mStr[0]=(double)stuStr[n][0]/n; System.out.printf("%.2f",mStr[0]); for(int i=1;i<m;i++){ mStr[i] = (double)stuStr[n][i]/n; System.out.printf(" %.2f",mStr[i]); } System.out.println(); int sum=0; for(int i=0;i<n;i++){ int sum_s = 0; for(int j=0;j<m;j++){ if(mStr[j]<=stuStr[i][j]){ sum_s++; } } if(sum_s==m){ sum++; } } System.out.println(sum); System.out.println(); } }
}
  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52

文章来源: chenhx.blog.csdn.net,作者:谙忆,版权归原作者所有,如需转载,请联系作者。

原文链接:chenhx.blog.csdn.net/article/details/50249095

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。