改错题
给定程序中函数fun的功能是:对N名学生的学习成绩,按从高到低的顺序找出前m(m≤10)名学生来,并将这些学生数据存放在一个动态分配的连续存储区中,此存储区的首地址作为函数值返回。
请改正函数fun中指定部位的错误,使它能得出正确的结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!
给定源程序:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define N 10
typedef struct ss
{char num[10];
int s;
}STU;
STU*fun(STU a[],int m)
{STU b[N],*t;
int i,j,k;
/**********found**********/
t=(STU*)calloc(sizeof(STU),m)
for(i=0;i<N;i++)b[i]=a[i];
for(k=0;k<m;k++)
{for(i=j=0;i<N;i++)
if(b[i].s>b[j].s)j=i;
/**********found**********/
t(k)=b(j);
b[j].s=0;
}
return t;
}
void outresuh(STU at],FILE*pf)
{int i;
for(i=0;i<N;i++)
fprintf(pf,'No=%s Mark=%d\n',a[i],num,a[i].s);
fprintf(pf,'\n\n');
}
main()
{STU a[N]={{'A01',81},{'A02',89},{'A03',66},{'A04',87},{'A05',77},{'A06',90},{'A07',79},{'A08',61},{'A09',80},{'A10',71}};
STU*pOrder;
int i,m;
printf('*****The Original data*****\n');
outresult(a,stdout);
printf('\nGive the number of the students who have better score:');
scanf('%d',&m);
while(m>10)
{printf('\nGive the number of the students who have better score:');
scanf('%d',&m);
}
pOrder=fun(a,m);
printf('*****THE RESULT*****\n');
printf('The top:\n');
for(i=0;i<m;i++)
printf('%s %d\n',pOrder[i].num,pOrder[i].s);
free(pOrder);
}
【正确答案】(1)t=(STU *)calloc(sizeof(STU),m); (2)t[k]=b[j];
【答案解析】(1)calloc应用于分配内存空间。调用形式为(类型说明符*)calloc(n,size),功能:在内存动态存储区中分配n块长度为'size'字节的连续区域,函数的返回值为该区域的首地址,(类型说明符*)用于强制类型转换。calloc函数与malloc函数的区别在于calloc函数一次可以分配n块区域。例如,ps=(struct stu*)calloc(2,sizeof(struct stu));,其中的sizeof(struct stu)是求stu的结构长度。该语句的意思是:按stu的长度分配两块连续区域,强制转换为stu类型,并把其首地址赋予指针变量ps。在本题中不用考虑那么复杂,根据定义类型STU b[N],*t;就可以看出*t=calloc(m,sizeof(STU))中的错误。 (2)t[k].num=b[j].num的错误旨在考查对结构体概念的掌握和灵活应用程度。