题目:学生记录由学号和成绩组成,N名学生的数据已放入主函数中的结构体数组中,请编写函数fun,其功能是:把分数最低的学生数据放入b所指的数组中,注意:分数最低的学生可能不止一个,函数返回分数最低的学生人数。
编译环境:VS2010
#include<stdio.h>
#define N 16
typedef struct
{
char num[10];
int s;
}STREC;
int fun(STREC *a, STREC *b)
{
/******begin******/
/******end******/
}
void main()
{
STEREC 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;
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");
}
答案与解析
1.结构体成员名访问+数组指针
int i, j = 0,min = a[0].s;
for(i = 0;i < N;i++)
if(min > a[i].s)
min = a[i].s;
for(i = 0;i < N;i++)
if(min == a[i].s)
b[j++] == a[i];
return j;
2.通过指针访问结构体成员
STREC *p = a;
int min = p -> s;
int i, cnt = 0;
for(i = 0;i < N;i++)
{
if(min > p -> s) min = p -> s;
p++;
}
for(i = 0;i < N;i++)
{
if(a -> s == min)
{
*b = *a;
b++;
cnt++;
}
a++;
}
return cnt;
PS:此处输入数据时易误写成while(p !=NULL)
但是请注意只有链表才能用此类写法,而本题只是一个结构体数组。