編程題
學(xué)生的記錄由學(xué)號(hào)和成績(jī)組成,N名學(xué)生的數(shù)據(jù)已在主函數(shù)中放入結(jié)構(gòu)體數(shù)組S中,請(qǐng)編寫(xiě)函數(shù)FUN,它的功能是:把分?jǐn)?shù)最高的學(xué)生數(shù)據(jù)放在H所指的數(shù)組中,注意:分?jǐn)?shù)最高的學(xué)生可能不只一個(gè),函數(shù)返回分?jǐn)?shù)最高的學(xué)生的人數(shù)。
注意:部分源程序給出如下。
請(qǐng)勿改動(dòng)主函數(shù)main和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)fun的花括號(hào)中填入所編寫(xiě)的若干語(yǔ)句。
試題程序:
#include
#define N 16
typedef struct
{
char num[10];
int s;
} STREC;
int fun ( STREC *a, STREC *b )
{
} 來(lái)源:1glr.cn
main ()
{
STREC s[N]= {{"GA05",85}, {"GA03",76}, {"GA02",69}, {"GA04",85},
{"GA01",91}, {"GA07",72}, {"GA08",64}, {"GA06", 87},
{"GA015",85}, {"GA013",91}, {"GA012",64}, {"GA014",91},
{"GA011",77}, {"GA017",64}, {"GA018",64}, {"GA016",72}};
STREC h[N];
int i, n;
FILE *out;
n=fun ( s, h );
printf ("The %d highest score :\n", n);
for (i=0; i printf ("%s %4d\n", h[i]. num, h[i]. s); printf ("\n"); out=fopen ("out.dat", "w"); fprintf (out, "%d\n", n); for (i=0; i fprintf (out, "%4d\n", h[i].s); fclose (out ); } 答案是: int fun(STREC *a,STREC *b) { int I,j=0,n=0,max; max=a[0].s; for(i=0;i if(a[i].s>max) max=a[i].s; for(i=0;i if(a[i].s==max) { *(b+j)=a[i]; j++; n++; } return n; }
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |