程序通过定义学生结构体变量,存储了学生的学号、姓名和3门课的成绩。所有学生数据均以二进制:疗式输出到文件中。函数fun的功能是从形参filename所指的文件中读入学生数据,并按照学号从小到大排序后,再用二进制方式把排序后的学生数据输出到filename所

admin2015-08-23  32

问题 程序通过定义学生结构体变量,存储了学生的学号、姓名和3门课的成绩。所有学生数据均以二进制:疗式输出到文件中。函数fun的功能是从形参filename所指的文件中读入学生数据,并按照学号从小到大排序后,再用二进制方式把排序后的学生数据输出到filename所指的文件中,覆盖原来的文件内容。
    请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
    注意:源程序存放在考生文件夹下的BLANK1.C中。
    不得增行或删行,也不得更改程序的结构!
#inolude  
#define N 5
typedef struct student{
  long sno;
  char name[10];
  float scoee[3];
}STU;
void fun(char *filerlame)
{FILE*fp;int i,j;
  STU s[N],t;
/**********found**********/
  fp=fopen(filename,_____1_____);
  fread(s,sizeof(STU),N,fp);
  fclose(fp);
  for(2=0;i    for(j=i+1; j/**********found**********/
    if(S.sno _____2_____s[j].srlo)
    {t=s; s=s[j]; S[j]=t;}
  fp=fopen(filename,"wb");
/**********found**********/
    3  (s,si zeof(STU),N,fp);/*二
进制输出*/
  fclose(fp);
}
main()
{STU t[N]={{10005,"ZhangSan",95,80,88),
{10003,"LiSi",8 5,70,78),
{10002,"CaoKai",75,60,88),
{10004,"FangFang",90,82,87},
{10001, "Nachao",91,92,77}),ss[N];
  int i,j ; FILE*fp;
  fp=fopen("student.dat","wb");
  fwrite(t,sizeof(STU),5,fp);
  fclose(fp);
  printf("\n\nThe  original data:\n\n");
  for(j=0;j  {printf("\nNo:%ld Name:%一8S
Scores:",t[j].sno,t[j].name);
    for  (i=0;  i<3;  i++)printf
("%6.2f",t[j].score);
    printf("\n");
    }
    fun("stuctent.dat");
    printf("\n\nThe data after sorting:
\n\n");
  fp=fopen("student.dat","rb");
  fread(ss,sizeof(STU),5,fp);
  fclose(fp);
  for(j=0; j  {printf("\nNo:%ld Name:%一8s
Scores:",s s[j].sno,  ss[j].name);
    for  (i=0;  i<3;  i++)printf
("%6.2 f",ss[j].score);
    printf("\n");
  }
}

选项

答案(1)"rb" (2)> (3)fwrite

解析 第一空:根据题干要求,“fp=fopen(filename,  1);”是打开filename所指文件,读出学生数据“fread(s,sizeof(STU),N,fp);”,然后关闭文件“fclose(fp)”,故第一空处是只读方式打开文件,因此第一空处应为“"rb"”。
第二空:根据题意,for循环是将学生数据按照学号从小到大排序后,这里采用的是冒泡法排序,如果发现前面的数据比后面的大则交换,故第二空处应为“>”。
第三空:文件是以只写方式(“wb”)打开,执行“_____3_____(s,sizeof(STU),N,fp);”后,关闭文件,即第三处是一次把所有学生数据写入文件,这是执行数据块写函数fwrite,故第三空处为“fwrite”。
转载请注明原文地址:https://jikaoti.com/ti/aSi0FFFM
0

最新回复(0)