所属年份:2011.3;2011.9;
已知学生的记录由学号和学习成绩构成,N名学生的数据已存入a结构体数组中。请编写函数fun,该函数的功能是:找出成绩最高的学生记录,通过形参返回主函数(规定只有一个最高分)。已给出函数的首部,请完成该函数。
#include<stdio.h> #include<string.h> #include<conio.h> #include<stdlib.h> #define N 10 typedef struct ss /*定义结构体*/ { char num[10]; int s; } STU; fun(STU a[], STU *s) { } void main() { FILE *wf; 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); /******************************/ wf=fopen("out.dat","w"); fprintf(wf,"%s,%d",m.num,m.s); fclose(wf); /*****************************/ }
【考点分析】
本题考查:成绩最高的学生记录查找;for循环语句;if条件语句。
【解题思路】
本题的流程是先使s指向第1名学生,利用循环语句遍历所有学生的成绩,利用条件语句判断当前学生成绩是否最高,所以if语句的条件是s->ss”等价于”(*s).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]; }