码迷,mamicode.com
首页 > 其他好文 > 详细

hdu 2023 求平均成绩

时间:2015-08-10 22:27:48      阅读:164      评论:0      收藏:0      [点我收藏+]

标签:

本题链接:点击打开链接

本题题意:

        有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;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

hdu 2023 求平均成绩

标签:

原文地址:http://blog.csdn.net/lsgbb/article/details/47403625

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!