已知学生的记录由学号和学习成绩构成,N名学生的数据已存入a结构体数组中。请编写函数fun(),该函数的功能是;找出成绩最高的学生记录,通过形参返回主函数(规定只有一个最高分)。已给㈩函数的首部,请完成该函数。 注意:部分源程序给出如下。 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。 试题程序: #include<stdio.h> #include<string.h> #include<conio.h> #define N 10 typedef struct ss /*定义结构体*/ { char num[10]; int s; } STU; fun(STU a[], STU *s) { } main ( ) { STU a[N]={{ "A01",81},{ "A02",89}, { "A03",66},{ "A04",87},{ "A05",77}, { "A06",90},{ "A07",79}, { "A08",61}, { "A09",80},{ "A10",71}},m; int i; clrscr (); printf("*****The original data*****"); for (i=0; i<N; i++) printf("No=%s Mark=%d\n", a[i].hum,a[i].s); fun (a, &m); printf ("*****THE RESULT*****\n"); printf("The top :%s, %d\n",m.num, m.s); }
参考答案:
解析:fun(STU a[], STU *s) { int i; *s=a[0]; for (i=0; i<N; i++) /*找出成绩最高的学生记录*/ if (s->s<a [i].s) *s==a [i]; } 本题的流程是这样的,先使s指向第1个学生,我们的题干目的是找出分数最高的学生,所以if语句的条件是 s->s<a[i].s。此外,在做本题时,我们应该熟练掌握“指向运算符”和“成员运算符”的相关知识。题中“s->s”也可换成“(*s).s”。