hdu 2023 求平均成績(c語言)
阿新 • • 發佈:2018-12-25
hdu 2023 求平均成績
題目描述
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
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
題目難點
1. 開闢一個二維陣列grade[ 50 ][ 5 ]儲存每個學生每門課的成績,陣列最好是double型,萬一出現小數好處理
2. 開闢一個stu_aver[50]陣列儲存每個學生的平均成績
3. 開闢一個pro_aver[5]陣列儲存每門課的平均成績
問題解答
#include <stdio.h>
int main()
{
int m, n;//n是學生數,m是課程數
int Count = 0;//Count:各科成績均大於等於平均成績的學生數量
double grade[50][5];//grade陣列:儲存每個學生每門課的成績
double stu_aver[50];//stu_aver陣列:儲存每個學生的平均成績
double pro_aver[5];//pro_aver陣列:儲存每門課的平均成績
double stu_average, pro_average;//每個學生的和每門課的平均成績
while( scanf( "%d%d",&n,&m ) != EOF )
{
Count = 0;//每進行一次迴圈,Count就要重新初始化為0
/*輸入每個同學每門課的成績*/
for(int i=0; i<n; ++i)
for(int j=0; j<m; ++j)
scanf( "%lf", &grade[i][j] );
/*算出每個同學的平均成績,並把其儲存到相應陣列中*/
for(int i=0; i<n; ++i)
{
stu_average = 0;//每次算新的同學都需初始化
for(int j=0; j<m; ++j)
stu_average += grade[i][j];//得到這位同學成績總和
stu_aver[i] = stu_average / (m*1.0);//得到這位同學的平均成績並存儲於陣列中
}
/*算出每門課的平均成績,並把其儲存到相應陣列中*/
for(int j=0; j<m; ++j)
{
pro_average = 0;
for(int i=0; i<n; ++i)
pro_average += grade[i][j];
pro_aver[j] = pro_average / (n*1.0);
}
/*計算各科成績均大於等於平均成績的學生數量*/
for(int i=0; i<n; ++i)
{
int key = 1;//開關
for(int j=0; j<m; ++j)
{
if( grade[i][j] < pro_aver[j] )
key = 0;//只要有一個不滿足,開關就關上
}
if( key == 1 ) Count++;//只有開關開啟的同學才能被計數
}
/*列印每個學生的平均成績*/
printf( "%.2lf", stu_aver[0] );
for(int i=1; i<n; ++i)
printf( " %.2lf",stu_aver[i] );
printf( "\n" );
/*列印每門課的平均成績*/
printf( "%.2lf", pro_aver[0] );
for(int i=1; i<m; ++i)
printf( " %.2lf", pro_aver[i] );
printf( "\n" );
/*最毒瘤的是這邊要列印兩個空行,不然AC不了*/
printf( "%d\n\n", Count );
}
return 0;
}