问答题
已知学生的记录由学号和学习成绩构成,N名学生的数据已存入a结构体数组中。请编写函数fun,该函数的功能是:找出成绩最高的学生记录,通过形参返回主函数(规定只有一个最高分)。已给出函数的首部,请完成该函数。
注意:部分源程序给出如下。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
试题程序:
#include<stdlib.h>
#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)
{
}
void 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;
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”。