第43题
学生的记录由学号和成绩组成,N名学生的数据已在主函数中敲入
结构体数组s中,请编写函数fun,它的功能是:按分数的高低排列学
生的记录,高分在前。 注意:部分源程序给出如下。请勿改动主函数main和其它函数中
的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
/**********code.c**********/
#include <stdio.h>
#define N 16
typedef struct
{
char num[10];
int s;
}STREC;
void fun( STREC a[] )
{
STREC tmp; int i,j;
for(i = 1; i < N; i++)
for(j = 0; j < N-1; j++)
{
/*请按题目要求,完成一下代码*/
}
}
void main()
{
STREC s[N] = {{"GA005",85}, {"GA003",76}, {"GA002",69},{"GA004",85}, {"GA001",91}, {"GA007",72},
{"GA008",64},{"GA006",87},{"GA015",85}, {"GA013",91}, {"GA012",64}, {"GA014",91},{"GA011",66},
{"GA017",64}, {"GA018",64}, {"GA016",72}};
int i;
FILE *out ;
fun(s);
printf("The data after sorted :\n");
for(i=0;i<n; i++) {
if((i)%4==0)
printf("\n");
printf("%s %4d ",s[i].num,s[i].s); }
printf("\n");
out=fopen("out.dat","w");
for(i=0;i<N;i++)
{
if((i)%4==0&&i)fprintf(out, "\n");
fprintf(out, "%4d ",s[i].s);
}
fprintf(out,"\n");
fclose(out);
}
参考答案:
if(a[i].s<a[j].s)
{
tmp=a[j];
a[j]=a[i];
a[i]=tmp;
}