1. 程式人生 > >hdu 2023 求平均成績(c語言)

hdu 2023 求平均成績(c語言)

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