国家二级C语言机试(操作题)模拟试卷704
程序填空题
1.程序通过定义学生结构体变量,存储了学生的学号、姓名和3门课的成绩。所有学生数据均以二进制方式输出到文件中。函数fun的功能是重写形参filename所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其他学生的数据不变。
请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
注意:源程序存放在考生文件夹下的BLANK1.C中。
不得增行或删行,也不得更改程序的结构!
1 #include<stdio.h>
2 #define N 5
3 typedef struct student{
4 long sno;
5 char name[10];
6 float score[3];
7 } STU;
7 void fun(ohar *filename,STU n)
9 {FILE *fp;
10 /**********found**********/
11 fp=fopen(__1__,’’rb+’’);
12 /**********found**********/
13 fseek(__2__,-(long)sizeof(STU),SEEK_END);
14 /**********found**********/
15 fwrite(&n,sizeof(STU),1,__3__);
16 fclose(fp);
17 }
18 main()
19 {STU t[N]={{10001,’’MaChao’’,91,92,77},{10002,’’CaoKai’’,75,60,88},{10003,’’LiSi’’,85,70,78},(10004,’’FangFang’’,90,82,87},(10005,’’ZhangSan’’,95,80,88}};
20 STU n={10006,’’ZhaoSi’’,55,70,68},ss[N];
21 int i,j;FILE *fp;
22 fp=fopen(’’student.dat’’,’’wb’’);
23 fwrite(t,sizeof(STU),N,fp);
24 fclose(fp);
25 fp=fopen(’’student.dat’’,’’rb’’);
26 fread(ss,sizeof(STU),N,fp);
27 fclose(fp);
28 printf(’’\nThe original data:\n\n’’);
29 for(j=O;j<N;j++)
30 {printf(’’\nNo:%1d Name:%-8s ScoEes:’’,ss[j].sno,ss[j].name);
31 for(i=0;i<3;i++) printf(’’%6.2f’’,ss[j].score[i]);
32 printf(’’\n’’);
33 }
34 fun(’’student.dat’’,n);
35 printf(’’\nThe data after modifing:\n\n’’);
36 fp=fopen(’’student.dat’’,’’rb’’);
37 fread(ss,sizeof(STU),N,fp);
38 fclose(fp);
39 for(j=0;j<N;j++)
40 {printf(’’\nNo:%1d Name:%-8s Scores:’’,ss[j].sno,ss[j].name);
41 for(i=0;i<3;i++)printf(’’%6.2f’’,ss[j].score[i]);
42 printf(’’\n’’);
43 }
44 }
(1)filename
(2)fp
(3)fp
解析:本题中函数fun的功能是重写形参filename所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,本题主要考察文件的读写。
第一空:“fp=fopen(__1__,’’fb+’’);”补充fopen的参数,fopen的调用形式是:fp=fopen(文件名,文件使用方式),因此,第一空处应填文件名“filename”。
第二空:此处是补充fseek函数的参数,fseek的调用形式是:fseek(fp,offset,position),其中,第一个参数是文件型指针,故第二空处应填文件型指针变量“fp“。
第三空:fwrite的调用形式是(buffer,size,count,fp),最后一个参数是文件型指针,故第三空处应填“fp”,将新的学生数据写在最后一个学生数据位置。
程序修改题
2.给定程序MODI1.C中的函数Creatlink的功能是创建带头结点的单向链表,并为各结点数据域赋0到m-1的值。
请改正函数Crealink中指定部位的错误,使它能得出正确的结果。
注意:不要改动mam函数,不得增行或删行,也不得更改程序的结构!
1 #include<stdio.h>
2 #include<stdlib.h>
3 typedef struct aa
4 { int datal
5 struct aa *next;
6 } NODE;
7 NODE *Creatlink(int n,int m)
8 {NODE *h=NULL,*p,*s;
9 int i;
10 /**********found**********/
11 p=(NODE)malloc(sizeof(NODE));
12 h=p;
13 p->next=NULL;
14 for(i=1;i<=n;i++)
15 {s=(NODE *)malloc(sizeof(NODE));
16 s->data=rand()%m;s->next=p->next;
17 p->next=s;p=p->next;
18 }
19 /**********found**********/
20 return p;
21 }
22 outlink(NODE *h)
23 { NODE *p;
24 p=h->next;
25 printf(’’\n\nTHE LIST:\n\n HEAD’’);
26 while(p)
27 {printf(’’->%d’’,p->data);
28 p=p->next;
29 }
30 printf(’’\n’’);}
31 main()
32 { NODE *head;
33 head=Creatlink(8,22);
34 outlink(head);}
(1)p=(NODE*)mal
本文档预览:3600字符,共5540字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载