活动设计题   学生的记录由学号和成绩组成,N名学生的数据已在主函数中放入结构体数组s中,请编写函数fun,它的功能是:把分数最低的学生数据放在b所指的数组中,注意:分数最低的学生可能不止一个,函数返回分数最低的学生的人数。
    注意:部分源程序在文件PROG1. C文件中。
    请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
    #include <stdio. h>
    #define N 16
    typedef struct
    { char num[10];
    int s;
    }STREC;
    int fun(STREC *a, STREC *b)
    {
    }
    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', 91}, {'GA017', 64},
    {'GA018', 64), {'GA016', 72}};
    STREC h[N];
    int i, n; FILE *out;
    n=fun(s, h);
    printf('The %d lowest score:\n', n);
    for(i=0; i<n; 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<n; i++)
    fprintf(out, '%4d\n', h[i]. s);
    fclose(out);
    }
 
【正确答案】int i, j=0, min=a[0]. s; for(i=0; i<N; i++) { if(min>a[i].s) { j=0; b[j++]=a[i]; min=a[i]. s; } else if(min==a[i]. s) b[j++]=a[i]; } return j;
【答案解析】该程序功能是把分数最低的学生数据放在b所指的数组中。本题是关于求解结构体中某些成员的最小值,首先将第一个值设定为最小值,并在循环中将其他所有值与该值进行比较,求得最小值。然后将最小值与所有值进行比较,求得所有的最小值。 (1)要把最低分数的学生数据放在数组中,首先求出最低分数,再使用一个for循环把所有的成绩进行比较,找出最低的分数来。 (2)找出所有与最低分数相等的学生,并将最低分数的人数累加。 [考点] 结构体数组、for循环结构。