hdu 2023 求平均成绩
2015-08-10 19:53
501 查看
本题链接:点击打开链接
本题题意:
有n名学生,m门课程,输入每个学生没门课程的成绩,求每个学生的平均成绩和没门课程的平均成绩,并统计每门课程的成绩均超过该课程平均成绩的学生有多少名。
解题思路:
本题主要是使用三个数组,一个score二维数组存放每个学生每门课的成绩,然后两个一维数组student和subject分别存放每个学生的平均成绩及每门课的平均成绩。具体请参考代码:
本题题意:
有n名学生,m门课程,输入每个学生没门课程的成绩,求每个学生的平均成绩和没门课程的平均成绩,并统计每门课程的成绩均超过该课程平均成绩的学生有多少名。
解题思路:
本题主要是使用三个数组,一个score二维数组存放每个学生每门课的成绩,然后两个一维数组student和subject分别存放每个学生的平均成绩及每门课的平均成绩。具体请参考代码:
#include<stdio.h> #include<string.h> double student[55],subject[9]; double score[55][9];//二维数组,每行存的每个学生的分数,每列为每门课的分数 int main() { int n,m; while(scanf("%d%d",&n,&m)!=EOF) { for(int i=0;i<n;i++) for(int j=0;j<m;j++) scanf("%lf",&score[i][j]); double sumstu,sumsub; for(int i=0;i<n;i++) { sumstu=sumsub=0; for(int j=0;j<m;j++) { sumstu+=score[i][j];//每个学生的总分 // sumsub+=score[j][i]; } student[i]=sumstu/m;//每个学生的平均分 // subject[i]=sumsub/(n*1.0); } for(int i=0;i<m;i++) { sumsub=0; for(int j=0;j<n;j++) sumsub+=score[j][i];//每门课总分 subject[i]=sumsub/n;//每门课平均分 } int sum=0,flag; for(int i=0;i<n;i++) { flag=0; for(int j=0;j<m;j++) { if(score[i][j]<subject[j])//若有一门分数小于该科目平均分,则不满足 { flag=1; break; } } if(flag==0) sum++; } for(int i=0;i<n-1;i++) printf("%.2lf ",student[i]); printf("%.2lf\n",student[n-1]); for(int i=0;i<m-1;i++) printf("%.2lf ",subject[i]); printf("%.2lf\n",subject[m-1]); printf("%d\n\n",sum); } return 0; }
相关文章推荐
- Could not connect to SMTP host: localhost, port: 25;
- UVA 10139 Factovisors(数论)
- Radar Installation
- Fbric、Ansible、Docker、Chaos Monkey:DevOps工具的年中回顾
- http和https的区别
- C语言-Array(High)
- 状压DP LIGHTOJ 1194 Colored T-Shirts
- AutoScrollViewPager 自动循环滚动viewpager
- 程序员保值的4个秘密
- 泛型
- Fbric、Ansible、Docker、Chaos Monkey:DevOps工具的年中回顾
- 《算法导论》读书笔记
- 大明A+B
- Map Labeler (poj 2296 二分+2-SAT)
- uva 10118 记忆化搜索
- CSU 1328 近似回文词
- 华为机试-倒置英文句中的单词
- 听课笔记(六)
- 【笔试】18、两个乒乓球队进行比赛
- OC与iOS开发