1、国家二级 C语言机试(操作题)模拟试卷 354及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.程序通过定义学生结构体变量,存储了学生的学号、姓名和 3门课的成绩。所有学生数据均以二进制方式输出到文件中。函数 fun的功能是重写形参 filename所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其他学生的数据不变。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANK1C 中。 不得增行或删行,也不得更改程序的结构!1 #includestdioh2 #defi
2、ne N 53 typedef struct student4 long sno;5 char name10;6 float score3;7 STU;8 void fun(char *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 tN=10001,MaChao,91,92,7
3、7,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,ssN;21 int i,j;FILE *fp;22 fp=fopen(studentdat,wb);23 fwrite(t,sizeof(STU),N,fp);24 fclose(fp);25 fp=fopen(studentdat,rb);26 fread(ss,sizeof(STU),N,fp);27 fclose(fp);28 printf(n
4、The original data:nn);29 for(j=0;jN;j+)30 printf(nNo:1d Name:-8s Scores:,ssjsno,ssjname);31 for(i=0;i3;i+) printf(62f,ssjscorei);32 printf(n);33 34 fun(studentdat,n);35 printf(nThe data after modifing:nn);36 fp=fopen(studentdat,rb);37 fread(ss,sizeof(STU),N,fp);38 fclose(fp);39 for(j=0;jN;j+)40 prin
5、tf(nNo:1d Name:-8s Scores:,ssjsno,ssjname);41 for(i=0;i3;i+)printf(62f,ssjscorei);42 printf(n);43 44 (分数:2.00)_二、程序修改题(总题数:1,分数:2.00)2.给定程序 modi1c 的主函数中,将 a、b、c 三个结点链成一个单向链表,并给各结点的数据域赋值,函数 fun()的作用是:累加链表结点数据域中的数据作为函数值返回。 请改正函数 fun中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构。1 #includestdio
6、h2 typedef struct list3 int data;4 struct list *next;5 LIST;6 int fun(LIST *h)7 LIST *p;8 *found*9 int t;10 p=h;11 *found*12 while(*p) 13 14 *found*15 t=t+pdata;16 p=(*p)next;17 18 return t;19 20 main()21 LIST a,b,c,*h;22 adata=34;bdata=51;23 cdata=87;cnext=0;24 h=a;anext=13 int i=0;14 rf=fopen(inda
7、t,r);15 wf=fopen(outdat,w);16 while(i10) 17 fgets(s,10,rf);18 s7=0 ;19 fun(s,7);20 fprintf(wf,sn,s);21 i+;22 23 fclose(rf);24 fclose(wf);25 26 main()27 28 char s10;29 printf(输入 7个字符的字符串:);30 gets(s);31 fun(s,7);32 printf(ns,s);33 NONO();34 (分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 354答案解析(总分:6.00,做题时间:90 分钟)一、程
8、序填空题(总题数:1,分数:2.00)1.程序通过定义学生结构体变量,存储了学生的学号、姓名和 3门课的成绩。所有学生数据均以二进制方式输出到文件中。函数 fun的功能是重写形参 filename所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其他学生的数据不变。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANK1C 中。 不得增行或删行,也不得更改程序的结构!1 #includestdioh2 #define N 53 typedef struct student4 long sno;5 char nam
9、e10;6 float score3;7 STU;8 void fun(char *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 tN=10001,MaChao,91,92,77,10002,CaoKai,75,60,88,10003,LiSi,85,70,78,10004,F
10、angFang,90,82,87,10005,ZhangSan,95,80,88;20 STU n=10006,ZhaoSi,55,70,68,ssN;21 int i,j;FILE *fp;22 fp=fopen(studentdat,wb);23 fwrite(t,sizeof(STU),N,fp);24 fclose(fp);25 fp=fopen(studentdat,rb);26 fread(ss,sizeof(STU),N,fp);27 fclose(fp);28 printf(nThe original data:nn);29 for(j=0;jN;j+)30 printf(nN
11、o:1d Name:-8s Scores:,ssjsno,ssjname);31 for(i=0;i3;i+) printf(62f,ssjscorei);32 printf(n);33 34 fun(studentdat,n);35 printf(nThe data after modifing:nn);36 fp=fopen(studentdat,rb);37 fread(ss,sizeof(STU),N,fp);38 fclose(fp);39 for(j=0;jN;j+)40 printf(nNo:1d Name:-8s Scores:,ssjsno,ssjname);41 for(i
12、=0;i3;i+)printf(62f,ssjscorei);42 printf(n);43 44 (分数:2.00)_正确答案:(正确答案:(1)filename (2)fp (3)fp)解析:解析:第一空:“fp=fopen(_1_,rb+);”补充 fopen的参数,fopen 的调用形式是:fp=fopen(文件名,文件使用方式),因此第一空处应填文件名“filename”。 第二空:此处是补充fseek函数的参数,fseek 的调用形式是:fseek(fp,offset,position),其中第一个参数是文件型指针,故第二空处应填文件型指针变量“fp”。 第三空:fwrite 的调
13、用形式是(buffer,size,count,fp),最后一个参数是文件型指针,故第三空处应填“fp”,将新的学生数据写在最后一个学生数据位置。二、程序修改题(总题数:1,分数:2.00)2.给定程序 modi1c 的主函数中,将 a、b、c 三个结点链成一个单向链表,并给各结点的数据域赋值,函数 fun()的作用是:累加链表结点数据域中的数据作为函数值返回。 请改正函数 fun中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构。1 #includestdioh2 typedef struct list3 int data;4 stru
14、ct list *next;5 LIST;6 int fun(LIST *h)7 LIST *p;8 *found*9 int t;10 p=h;11 *found*12 while(*p) 13 14 *found*15 t=t+pdata;16 p=(*p)next;17 18 return t;19 20 main()21 LIST a,b,c,*h;22 adata=34;bdata=51;23 cdata=87;cnext=0;24 h=a;anext=13 int i=0;14 rf=fopen(indat,r);15 wf=fopen(outdat,w);16 while(i10
15、) 17 fgets(s,10,rf);18 s7=0 ;19 fun(s,7);20 fprintf(wf,sn,s);21 i+;22 23 fclose(rf);24 fclose(wf);25 26 main()27 28 char s10;29 printf(输入 7个字符的字符串:);30 gets(s);31 fun(s,7);32 printf(ns,s);33 NONO();34 (分数:2.00)_正确答案:(正确答案:1 char t; 2 int i,j; 3 for(i=1;inum-2;i+) 4 对 n个元素进行循环选择 5 for(j=i+1;jnum-1;j+) 6 if(sisj) 7 将 stri设为最大值,和剩下的jnum-1 进行比较 8 t=si; 9 si=sj; 10 sj=t; 11 )解析:解析:选择排序法中的降序排序,首先从数组中挑选一个最大的元素,把它和第一个元素交换,接着从剩下的 num-1个元素中再挑出一个最大的元素,把它和第二个元素交换,不断重复以上过程,直到比较完最后两个元素。