问答题 已知学生的记录由学号和学习成绩构成,N名学生的数据已存入a结构体数组中。请编写函数fun,该函数的功能是:找出成绩最高的学生记录,通过形参返回主函数(规定只有一个最高分)。已给出函数的首部,请完成该函数。注意:部分源程序给出如下。请勿改动主函数nmin和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。试题程序:#include<stdlib.h>#include<stdio.h>#include<string.h>#include<conio.h>#defitie N 10 typedef struct ss /*定义结构体*/{ char num[10]; int s;}STU;fun(STU a[],STU *s){}void main(){ STU a[N]={{"A01",81},{"A02",89},{"A03",66},{"A04",87},{"A0 5",77},{"A06",90},{"A07",79},{"A08",61},{"A09",80),{"A10",71}},m; int i ; system("CLS"); printf("****The original data****"); for(i=0;i<N;i++) printf("No=%s Mark=%d\n",a[i].num,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”。